diff options
author | unknown <monty@mashka.mysql.fi> | 2004-02-20 17:43:02 +0200 |
---|---|---|
committer | unknown <monty@mashka.mysql.fi> | 2004-02-20 17:43:02 +0200 |
commit | 8b2b219fb5e1374abdd816d9d0911d37087c86a5 (patch) | |
tree | e13a23a1c9f28ed5eb2d903ba59a153cda3355ac /innobase | |
parent | 51a6b4f47ad03031105b0f8ac810d522a804695e (diff) | |
parent | 9bc5cdba41a0d2bc3c391469b14168f82e636a6b (diff) | |
download | mariadb-git-8b2b219fb5e1374abdd816d9d0911d37087c86a5.tar.gz |
merge with 4.0 to get security fixes and latest bug fixes
BitKeeper/etc/logging_ok:
auto-union
configure.in:
Auto merged
BitKeeper/deleted/.del-mini_client.cc~8677895ec8169183:
Auto merged
VC++Files/mysql.dsw:
Auto merged
VC++Files/mysys/mysys.dsp:
Auto merged
innobase/buf/buf0buf.c:
Auto merged
innobase/include/srv0start.h:
Auto merged
innobase/lock/lock0lock.c:
Auto merged
innobase/mem/mem0dbg.c:
Auto merged
innobase/que/que0que.c:
Auto merged
innobase/srv/srv0start.c:
Auto merged
innobase/sync/sync0rw.c:
Auto merged
innobase/sync/sync0sync.c:
Auto merged
innobase/trx/trx0trx.c:
Auto merged
libmysql/manager.c:
Auto merged
sql/ha_innodb.cc:
Auto merged
sql/sql_load.cc:
Auto merged
sql/sql_yacc.yy:
Auto merged
sql/unireg.cc:
Auto merged
VC++Files/sql/mysqld.dsp:
Removed wrong define USE_SYMLINK
include/config-win.h:
Use original code
innobase/srv/srv0srv.c:
merge
innobase/usr/usr0sess.c:
merge
libmysql/libmysql.c:
merge
mysql-test/r/func_test.result:
merge
mysql-test/t/func_test.test:
merge
sql/log.cc:
merge
sql/mysqld.cc:
merge
Diffstat (limited to 'innobase')
81 files changed, 91 insertions, 49753 deletions
diff --git a/innobase/btr/ts/isql.c b/innobase/btr/ts/isql.c deleted file mode 100644 index db56aa65a66..00000000000 --- a/innobase/btr/ts/isql.c +++ /dev/null @@ -1,312 +0,0 @@ -/************************************************************************ -Test for the client: interactive SQL - -(c) 1996-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "univ.i" -#include "ib_odbc.h" -#include "mem0mem.h" -#include "sync0sync.h" -#include "os0thread.h" -#include "os0proc.h" -#include "os0sync.h" -#include "srv0srv.h" - -ulint n_exited = 0; - -char cli_srv_endpoint_name[100]; -char cli_user_name[100]; - -ulint n_warehouses = ULINT_MAX; -ulint n_customers_d = ULINT_MAX; -bool is_tpc_d = FALSE; -ulint n_rounds = ULINT_MAX; -ulint n_users = ULINT_MAX; -ulint startdate = 0; -ulint enddate = 0; -bool own_warehouse = FALSE; - -ulint mem_pool_size = ULINT_MAX; - -/************************************************************************* -Reads a keywords and a values from an initfile. In case of an error, exits -from the process. */ -static -void -cli_read_initfile( -/*==============*/ - FILE* initfile) /* in: file pointer */ -{ - char str_buf[10000]; - ulint ulint_val; - - srv_read_init_val(initfile, FALSE, "SRV_ENDPOINT_NAME", str_buf, - &ulint_val); - - ut_a(ut_strlen(str_buf) < COM_MAX_ADDR_LEN); - - ut_memcpy(cli_srv_endpoint_name, str_buf, COM_MAX_ADDR_LEN); - - srv_read_init_val(initfile, FALSE, "USER_NAME", str_buf, - &ulint_val); - ut_a(ut_strlen(str_buf) < COM_MAX_ADDR_LEN); - - ut_memcpy(cli_user_name, str_buf, COM_MAX_ADDR_LEN); - - srv_read_init_val(initfile, TRUE, "MEM_POOL_SIZE", str_buf, - &mem_pool_size); - - srv_read_init_val(initfile, TRUE, "N_WAREHOUSES", str_buf, - &n_warehouses); - - srv_read_init_val(initfile, TRUE, "N_CUSTOMERS_D", str_buf, - &n_customers_d); - - srv_read_init_val(initfile, TRUE, "IS_TPC_D", str_buf, - &is_tpc_d); - - srv_read_init_val(initfile, TRUE, "N_ROUNDS", str_buf, - &n_rounds); - - srv_read_init_val(initfile, TRUE, "N_USERS", str_buf, - &n_users); - - srv_read_init_val(initfile, TRUE, "STARTDATE", str_buf, - &startdate); - - srv_read_init_val(initfile, TRUE, "ENDDATE", str_buf, - &enddate); - - srv_read_init_val(initfile, TRUE, "OWN_WAREHOUSE", str_buf, - &own_warehouse); -} - -/************************************************************************* -Reads configuration info for the client. */ -static -void -cli_boot( -/*=====*/ - char* name) /* in: the initialization file name */ -{ - FILE* initfile; - - initfile = fopen(name, "r"); - - if (initfile == NULL) { - printf( - "Error in client booting: could not open initfile whose name is %s!\n", - name); - os_process_exit(1); - } - - cli_read_initfile(initfile); - - fclose(initfile); -} - -/********************************************************************* -Interactive SQL loop. */ -static -void -isql( -/*=*/ - FILE* inputfile) /* in: input file containing SQL strings, - or stdin */ -{ - HENV env; - HDBC conn; - RETCODE ret; - HSTMT sql_query; - ulint tm, oldtm; - char buf[1000]; - char* str; - ulint count; - ulint n_begins; - ulint len; - ulint n; - ulint i; - ulint n_lines; - - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLConnect(conn, (UCHAR*)cli_srv_endpoint_name, - (SWORD)ut_strlen(cli_srv_endpoint_name), - cli_user_name, - (SWORD)ut_strlen(cli_user_name), - (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - printf("Interactive SQL performs queries by first making a stored\n"); - printf("procedure from them, and then calling the procedure.\n"); - printf("Put a semicolon after each statement and\n"); - printf("end your query with two <enter>s.\n\n"); - printf("You can also give a single input file\n"); - printf("as a command line argument to isql.\n\n"); - printf("In the file separate SQL queries and procedure bodies\n"); - printf("by a single empty line. Do not write the final END; into\n"); - printf("a procedure body.\n\n"); - - count = 0; -loop: - count++; - n = 0; - n_lines = 0; - - sprintf(buf, "PROCEDURE P%s%lu () IS\nBEGIN ", cli_user_name, - count); - for (;;) { - len = ut_strlen(buf + n) - 1; - n += len; - - if (len == 0) { - break; - } else { - sprintf(buf + n, "\n"); - n++; - n_lines++; - } - - str = fgets(buf + n, 1000, inputfile); - - if ((str == NULL) && (inputfile != stdin)) { - /* Reached end-of-file: switch to input from - keyboard */ - - inputfile = stdin; - - break; - } - - ut_a(str); - } - - if (n_lines == 1) { - /* Empty procedure */ - - goto loop; - } - - /* If the statement is actually the body of a procedure, - erase the first BEGIN from the string: */ - - n_begins = 0; - - for (i = 0; i < n - 5; i++) { - - if (ut_memcmp(buf + i, "BEGIN", 5) == 0) { - - n_begins++; - } - } - - if (n_begins > 1) { - - for (i = 0; i < n - 5; i++) { - - if (ut_memcmp(buf + i, "BEGIN", 5) == 0) { - - /* Erase the first BEGIN: */ - ut_memcpy(buf + i, " ", 5); - - break; - } - } - } - - sprintf(buf + n, "END;\n"); - - printf("SQL procedure to execute:\n%s\n", buf); - - ret = SQLAllocStmt(conn, &sql_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(sql_query, (UCHAR*)buf, ut_strlen(buf)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(sql_query); - - ut_a(ret == SQL_SUCCESS); - - sprintf(buf, "{P%s%lu ()}", cli_user_name, count); - - ret = SQLAllocStmt(conn, &sql_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(sql_query, (UCHAR*)buf, ut_strlen(buf)); - - ut_a(ret == SQL_SUCCESS); - - printf("Starting to execute the query\n"); - - oldtm = ut_clock(); - - ret = SQLExecute(sql_query); - - tm = ut_clock(); - - printf("Wall time for query %lu milliseconds\n\n", tm - oldtm); - - ut_a(ret == SQL_SUCCESS); - - goto loop; -} - -/******************************************************************** -Main test function. */ - -void -main(int argc, char* argv[]) -/*========================*/ -{ - ulint tm, oldtm; - FILE* inputfile; - - if (argc > 2) { - printf("Only one input file allowed\n"); - - os_process_exit(1); - - } else if (argc == 2) { - inputfile = fopen(argv[1], "r"); - - if (inputfile == NULL) { - printf( - "Error: could not open the inputfile whose name is %s!\n", - argv[1]); - os_process_exit(1); - } - } else { - inputfile = stdin; - } - - cli_boot("cli_init"); - - sync_init(); - - mem_init(mem_pool_size); - - oldtm = ut_clock(); - - isql(inputfile); - - tm = ut_clock(); - - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/makefile b/innobase/btr/ts/makefile deleted file mode 100644 index 58364717472..00000000000 --- a/innobase/btr/ts/makefile +++ /dev/null @@ -1,16 +0,0 @@ -include ..\..\makefile.i - -doall: tssrv tscli isql - -tssrv: ..\btr.lib tssrv.c - $(CCOM) $(CFL) -I.. -I..\.. ..\btr.lib ..\..\eval.lib ..\..\ibuf.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tssrv.c $(LFL) - -tscli: ..\btr.lib tscli.c - $(CCOM) $(CFL) -I.. -I..\.. ..\btr.lib ..\..\ib_odbc.lib ..\..\eval.lib ..\..\ibuf.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tscli.c $(LFL) - -isql: ..\btr.lib isql.c - $(CCOM) $(CFL) -I.. -I..\.. ..\btr.lib ..\..\ib_odbc.lib ..\..\eval.lib ..\..\ibuf.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib isql.c $(LFL) - -tsrecv: ..\btr.lib tsrecv.c - $(CCOM) $(CFL) -I.. -I..\.. ..\btr.lib ..\..\ibuf.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsrecv.c $(LFL) - diff --git a/innobase/btr/ts/trash/TSIT.C b/innobase/btr/ts/trash/TSIT.C deleted file mode 100644 index 775d4036c6d..00000000000 --- a/innobase/btr/ts/trash/TSIT.C +++ /dev/null @@ -1,483 +0,0 @@ -/************************************************************************ -The test module for the record manager of MVB. - -(c) 1994 Heikki Tuuri - -Created 1/25/1994 Heikki Tuuri -*************************************************************************/ - - -#include "rm0phr.h" -#include "rm0lgr.h" -#include "ut0ut.h" -#include "buf0mem.h" -#include "rm0ipg.h" -#include "../it0it.h" -#include "../it0hi.h" -#include "../it0ads.h" - -byte buf[100]; -byte buf2[100]; -lint lintbuf[2048]; - -byte numbuf[6000]; -byte numlogrecbuf[100]; -phr_record_t* qs_table[100000]; - -lint qs_comp = 0; - -extern -void -test1(void); - -#ifdef NOT_DEFINED - -void -q_sort(lint low, lint up) -{ - phr_record_t* temp, *pivot; - lint i, j; - - - pivot = qs_table[(low + up) / 2]; - - i = low; - j = up; - - while (i < j) { - qs_comp++; - if (cmp_phr_compare(qs_table[i], pivot)<= 0) { - i++; - } else { - j--; - temp = qs_table[i]; - qs_table[i] = qs_table[j]; - qs_table[j] = temp; - } - } - - if (j == up) { - temp = qs_table[(low + up) / 2]; - qs_table[(low + up) / 2] = qs_table[up - 1]; - qs_table[up - 1] = temp; - j--; - } - - - if (j - low <= 1) { - /* do nothing */ - } else if (j - low == 2) { - qs_comp++; - if (cmp_phr_compare(qs_table[low], - qs_table[low + 1]) - <= 0) { - /* do nothing */ - } else { - temp = qs_table[low]; - qs_table[low] = qs_table[low + 1]; - qs_table[low + 1] = temp; - } - } else { - q_sort(low, j); - } - - if (up - j <= 1) { - /* do nothing */ - } else if (up - j == 2) { - qs_comp++; - if (cmp_phr_compare(qs_table[j], - qs_table[j + 1]) - <= 0) { - /* do nothing */ - } else { - temp = qs_table[j]; - qs_table[j] = qs_table[j + 1]; - qs_table[j + 1] = temp; - } - } else { - q_sort(j, up); - } -} - -#endif - -extern -void -test1(void) -{ - phr_record_t* physrec; - phr_record_t* rec1; - phr_record_t* rec2; - lgr_record_t* logrec; - lgrf_field_t* logfield; - lint len; - byte* str; - lint len2; - lint tm; - lint oldtm; - lint i, j, k, l, m; - bool b; - it_cur_cursor_t cursor; - ipg_cur_cursor_t* page_cursor; - ipg_page_t* page; - - byte c4, c3, c2, c1, c0; - lint rand, rnd1, rnd2; - byte* nb; - lgr_record_t* numlogrec; - byte* pgbuf; - mem_stream_t* stream; - lint tree1, tree2, tree3; - lint dummy1, dummy2; - - pgbuf = (byte*)lintbuf; - - stream = mem_stream_create(0); - - printf("-------------------------------------------\n"); - printf("TEST 1. Speed and basic tests.\n"); - - logrec = lgr_create_logical_record(stream, 2); - - nb = numbuf; - - c4 = '0'; - c3 = '0'; - for (c2 = '0'; c2 <= '9'; c2++) { - for (c1 = '0'; c1 <= '9'; c1++) { - for (c0 = '0'; c0 <= '9'; c0++) { - *nb = c4; nb++; - *nb = c3; nb++; - *nb = c2; nb++; - *nb = c1; nb++; - *nb = c0; nb++; - *nb = '\0'; nb++; - } - } - } - - numlogrec = lgr_create_logical_record(stream, 2); - - - tree1 = it_create_index_tree(); - - oldtm = ut_clock(); - - rand = 99900; - rnd1 = 67; - for (j = 0; j < 1; j++) { - for (i = 0 ; i < 100000; i++) { - - rand = (rand + 1) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); -/* - it_insert(tree1, numlogrec); -*/ - - - - it_cur_search_tree_to_nth_level(tree1, 1, numlogrec, - IPG_SE_L_GE, &cursor, &dummy1, &dummy2); - -/* - it_cur_set_to_first(tree1, &cursor); -*/ - - it_cur_insert_record(&cursor, numlogrec); - - } - } - tm = ut_clock(); - printf("Time for inserting %ld recs = %ld \n", i* j, tm - oldtm); - -/* it_print_tree(tree1, 10);*/ - hi_print_info(); - ads_print_info(); -/* - oldtm = ut_clock(); - - rand = 11113; - for (i = 0; i < 5000; i++) { - - rand = (rand + 57123) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); - - it_cur_search_tree_to_nth_level(tree1, 1, numlogrec, - IPG_SE_L_GE, &cursor, &dummy1, &dummy2); - - } - tm = ut_clock(); - printf("Time for searching %ld recs = %ld \n", i, tm - oldtm); -*/ - - it_cur_set_to_first(tree1, &cursor); - - rec1 = ipg_cur_get_record(it_cur_get_page_cursor(&cursor)); - - for (i = 0;; i++) { - it_cur_move_to_next(&cursor); - if (it_cur_end_of_level(&cursor)) { - break; - } - rec2 = ipg_cur_get_record(it_cur_get_page_cursor(&cursor)); - ut_a(cmp_phr_compare(rec1, rec2) == -1); - rec1 = rec2; - } - - printf("tree1 checked for right sorted order!\n"); - -#ifdef not_defined - - oldtm = ut_clock(); - - for (j = 0; j < 1; j++) { - rand = 11113; - for (i = 0; i < 3000; i++) { - - rand = (rand + 57123) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); - - physrec = hi_search(numlogrec); - - ut_a(physrec); - } - - } - ut_a(physrec); - tm = ut_clock(); - printf("Time for hi_search %ld recs = %ld \n", i * j, - tm - oldtm); - - - - oldtm = ut_clock(); - - for (i = 0; i < 100000; i++) { -/* j += lgr_fold(numlogrec, -1, -1);*/ -/* b += phr_lgr_equal(physrec, numlogrec, -1);*/ - k += ut_hash_lint(j, HI_TABLE_SIZE); - } - - -/* ut_a(b);*/ - tm = ut_clock(); - printf("Time for fold + equal %ld recs %s = %ld \n", i, physrec, - tm - oldtm); - - printf("%ld %ld %ld\n", j, b, k); - - hi_print_info(); - - tree2 = it_create_index_tree(); - - rand = 90000; - for (i = 0; i < 300; i++) { - - rand = (rand + 1) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); - - it_cur_search_tree_to_nth_level(tree2, 1, numlogrec, - IPG_SE_L_GE, &cursor); - - it_cur_insert_record(&cursor, numlogrec); - - } - - oldtm = ut_clock(); - - rand = 10000; - for (i = 0; i < 3000; i++) { - - rand = (rand + 1) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); - - it_cur_search_tree_to_nth_level(tree2, 1, numlogrec, - IPG_SE_L_GE, &cursor); - - it_cur_insert_record(&cursor, numlogrec); - - } - tm = ut_clock(); - printf("Time for inserting sequentially %ld recs = %ld \n", - i, tm - oldtm); - - -/* it_print_tree(tree2, 10); */ - - - tree3 = it_create_index_tree(); - - rand = 0; - for (i = 0; i < 300; i++) { - - rand = (rand + 1) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); - - it_cur_search_tree_to_nth_level(tree3, 1, numlogrec, - IPG_SE_L_GE, &cursor); - - it_cur_insert_record(&cursor, numlogrec); - - } - - oldtm = ut_clock(); - - rand = 100000; - for (i = 0; i < 3000; i++) { - - rand = (rand - 1) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); - - it_cur_search_tree_to_nth_level(tree3, 1, numlogrec, - IPG_SE_L_GE, &cursor); - - it_cur_insert_record(&cursor, numlogrec); - - } - tm = ut_clock(); - printf("Time for inserting sequentially downw. %ld recs = %ld \n", - i, tm - oldtm); - - -/* it_print_tree(tree3, 10); */ - -#endif - -} - -#ifdef NOT_DEFINED - -/* Test of quicksort */ -void -test2(void) -{ - mem_stream_t* stream; - byte* stbuf; - lgrf_field_t* logfield; - lint tm; - lint oldtm; - lint i, j, k, l, m; - lint rand; - lgr_record_t* numlogrec; - phr_record_t* ph_rec; - - stream = mem_stream_create(1000); - - numlogrec = lgr_create_logical_record(stream, 2); - - oldtm = ut_clock(); - - rand = 11113; - for (i = 0; i < 50000; i++) { - stbuf = mem_stream_alloc(stream, 30); - - rand = (rand + 57123) % 100000; - - logfield = lgr_get_nth_field(numlogrec, 0); - lgrf_set_data(logfield, numbuf + 6 * (rand / 300)); - lgrf_set_len(logfield, 6); - - logfield = lgr_get_nth_field(numlogrec, 1); - lgrf_set_data(logfield, numbuf + 6 * (rand % 300)); - lgrf_set_len(logfield, 6); - - ph_rec = phr_create_physical_record(stbuf, 30, numlogrec); - - qs_table[i] = ph_rec; - - } - tm = ut_clock(); - printf("Time for inserting %ld recs to mem stream = %ld \n", - i, tm - oldtm); - - - oldtm = ut_clock(); - - q_sort(0, 50000); - - tm = ut_clock(); - printf("Time for quicksort of %ld recs = %ld, comps: %ld \n", - i, tm - oldtm, qs_comp); - - - - for (i = 1; i < 49999; i++) { - ut_a(-1 == - cmp_phr_compare(qs_table[i], qs_table[i+1] - )); - } - tm = ut_clock(); - - - oldtm = ut_clock(); - for (i = 1; i < 50000; i++) { - k += cmp_phr_compare(qs_table[i & 0xF], - qs_table[5]); - } - tm = ut_clock(); - printf("%ld\n", k); - - printf("Time for cmp of %ld ph_recs = %ld \n", - i, tm - oldtm); - - mem_stream_free(stream); - -} -#endif - -void -main(void) -{ - test1(); -/* test2(); */ -} - diff --git a/innobase/btr/ts/trash/tsbtrold5.c b/innobase/btr/ts/trash/tsbtrold5.c deleted file mode 100644 index 370cf0b14bd..00000000000 --- a/innobase/btr/ts/trash/tsbtrold5.c +++ /dev/null @@ -1,798 +0,0 @@ -/************************************************************************ -The test for the index tree - -(c) 1994-1996 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "page0page.h" -#include "page0cur.h" -#include "..\btr0btr.h" -#include "..\btr0cur.h" -#include "..\btr0pcur.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 1 -#define N_FILES 2 -#define FILE_SIZE 1000 /* must be > 512 */ -#define POOL_SIZE 1000 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "j:\\tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[9] = (char)((ulint)'0' + k); - name[10] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space header of space 0. */ - -void -init_space(void) -/*============*/ -{ - mtr_t mtr; - - printf("Init space header\n"); - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -Test for index page. */ - -void -test1(void) -/*=======*/ -{ - dtuple_t* tuple; - mem_heap_t* heap; - ulint rnd = 0; - dict_index_t* index; - dict_table_t* table; - dict_tree_t* tree; - mtr_t mtr; - byte buf[8]; - ulint i; - ulint tm, oldtm; - btr_pcur_t cursor; - - printf("-------------------------------------------------\n"); - printf("TEST 1. Basic test\n"); - - heap = mem_heap_create(0); - - table = dict_mem_table_create("TS_TABLE1", 2); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - - dict_table_add_to_cache(table); - - index = dict_mem_index_create("TS_TABLE1", "IND1", 0, 2, 0); - - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - dict_index_add_to_cache(index); - - index = dict_index_get("TS_TABLE1", "IND1"); - ut_a(index); - - tree = dict_index_get_tree(index); - - tuple = dtuple_create(heap, 3); - - mtr_start(&mtr); - - btr_root_create(tree, 0, &mtr); - - mtr_commit(&mtr); - - mtr_start(&mtr); - - dtuple_gen_test_tuple3(tuple, 0, buf); - btr_insert(tree, tuple, &mtr); - - mtr_commit(&mtr); - - rnd = 90000; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - if (i == 77000) { - rnd = rnd % 200000; - } - - rnd = (rnd + 15675751) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - btr_insert(tree, tuple, &mtr); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - rnd = 90000; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - if (i == 50000) { - rnd = rnd % 200000; - } - - rnd = (rnd + 595659561) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - btr_pcur_open(tree, tuple, PAGE_CUR_GE, - BTR_SEARCH_LEAF, &cursor, &mtr); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - rnd = (rnd + 35608971) % 200000 + 1; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - -/* btr_print_tree(tree, 3); */ - - mem_heap_free(heap); -} - - -#ifdef notdefined - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 534671) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - -/* page_print_list(page, 151); */ - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 7771) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_get_n_recs(page) == 0); - - ut_a(page_validate(page, index)); - page = page_create(frame, &mtr); - - rnd = 311; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 217; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - page = page_create(frame, &mtr); - - rnd = 291; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 277; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - mem_heap_free(heap); -} - -/********************************************************************* -Test for index page. */ - -void -test2(void) -/*=======*/ -{ - page_t* page; - dtuple_t* tuple; - mem_heap_t* heap; - ulint i, j; - ulint rnd = 0; - rec_t* rec; - page_cur_t cursor; - dict_index_t* index; - dict_table_t* table; - buf_block_t* block; - buf_frame_t* frame; - ulint tm, oldtm; - byte buf[8]; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2. Speed test\n"); - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf, bigbuf + 800, 800); - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - rnd = 0; - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf + rnd, bigbuf + rnd + 800, 800); - rnd += 1600; - if (rnd > 995000) { - rnd = 0; - } - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - heap = mem_heap_create(0); - - table = dict_table_create("TS_TABLE2", 2); - - dict_table_add_col(table, "COL1", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL2", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - - ut_a(0 == dict_table_publish(table)); - - index = dict_index_create("TS_TABLE2", "IND2", 0, 2, 0); - - dict_index_add_field(index, "COL1", 0); - dict_index_add_field(index, "COL2", 0); - - ut_a(0 == dict_index_publish(index)); - - index = dict_index_get("TS_TABLE2", "IND2"); - ut_a(index); - - tuple = dtuple_create(heap, 2); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_get(0, 5, &mtr); - buf_page_s_lock(block, &mtr); - - page = buf_block_get_frame(block); - ut_a(page_validate(page, index)); - mtr_commit(&mtr); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for %lu empty loops with page create %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 100; - for (j = 0; j < 250; j++) { - rnd = (rnd + 1) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for sequential insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 500; - for (j = 0; j < 250; j++) { - rnd = (rnd - 1) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for descend. seq. insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - } - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insert and delete of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - ut_a(page_validate(page, index)); - mtr_print(&mtr); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - } - } - - tm = ut_clock(); - printf("Wall time for search of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - } - } - - tm = ut_clock(); - printf("Wall time for %lu empty loops %lu milliseconds\n", - i * j, tm - oldtm); - mtr_commit(&mtr); -} - -#endif - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - sync_init(); - mem_init(); - os_aio_init(160, 5); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - dict_init(); - fsp_init(); - log_init(); - - create_files(); - - init_space(); - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(); - -/* mem_print_info(); */ - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/trash/tscli.c b/innobase/btr/ts/trash/tscli.c deleted file mode 100644 index 622da894e02..00000000000 --- a/innobase/btr/ts/trash/tscli.c +++ /dev/null @@ -1,2263 +0,0 @@ -/************************************************************************ -Test for the client - -(c) 1996-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "ib_odbc.h" - -/********************************************************************* -Test for TPC-C. */ - -ulint -test_c( -/*===*/ - void* arg) -{ - HSTMT* query; - HSTMT* commit_query; - HSTMT* new_order_query; - HSTMT* payment_query; - HSTMT* order_status_query; - HSTMT* delivery_query; - HSTMT* stock_level_query; - HSTMT* print_query; - ulint tm, oldtm; - char* str; - char* str1; - char* str2; - char* str3; - char* str4; - char* str5; - char* str6; - ulint i; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST. CREATE TABLES FOR TPC-C\n"); - - /*------------------------------------------------------*/ - - str1 = - -" PROCEDURE CREATE_TABLES () IS" -" BEGIN" -" CREATE TABLE WAREHOUSE (W_ID CHAR, W_NAME CHAR," -" W_STREET_1 CHAR, W_STREET_2 CHAR," -" W_CITY CHAR," -" W_STATE CHAR, W_ZIP CHAR," -" W_TAX INT," -" W_YTD_HIGH INT," -" W_YTD INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX W_IND ON WAREHOUSE (W_ID);" -"" -" CREATE TABLE DISTRICT (D_ID CHAR, D_W_ID CHAR," -" D_NAME CHAR," -" D_STREET_1 CHAR, D_STREET_2 CHAR," -" D_CITY CHAR," -" D_STATE CHAR, D_ZIP CHAR," -" D_TAX INT," -" D_YTD_HIGH INT," -" D_YTD INT," -" D_NEXT_O_ID INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX D_IND ON DISTRICT (D_W_ID, D_ID);" -"" -" CREATE TABLE CUSTOMER (C_ID CHAR, C_D_ID CHAR, C_W_ID CHAR," -" C_FIRST CHAR, C_MIDDLE CHAR," -" C_LAST CHAR," -" C_STREET_1 CHAR, C_STREET_2 CHAR," -" C_CITY CHAR," -" C_STATE CHAR, C_ZIP CHAR," -" C_PHONE CHAR," -" C_SINCE_TIME INT," -" C_SINCE INT," -" C_CREDIT CHAR," -" C_CREDIT_LIM_HIGH INT," -" C_CREDIT_LIM INT," -" C_DISCOUNT INT," -" C_BALANCE_HIGH INT," -" C_BALANCE INT," -" C_YTD_PAYMENT_HIGH INT," -" C_YTD_PAYMENT INT," -" C_PAYMENT_CNT INT," -" C_DELIVERY_CNT INT," -" C_DATA CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX C_IND ON CUSTOMER (C_W_ID, C_D_ID," -" C_ID);" -"" -" CREATE INDEX C_LAST_IND ON CUSTOMER (C_W_ID, C_D_ID, C_LAST," -" C_FIRST);" -"" -" CREATE TABLE HISTORY (H_C_ID CHAR, H_C_D_ID CHAR, H_C_W_ID CHAR," -" H_D_ID CHAR, H_W_ID CHAR," -" H_DATE INT," -" H_AMOUNT INT," -" H_DATA CHAR);" -"" -" CREATE CLUSTERED INDEX H_IND ON HISTORY (H_W_ID);" -"" -" CREATE TABLE NEW_ORDER (NO_O_ID INT," -" NO_D_ID CHAR," -" NO_W_ID CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX NO_IND ON NEW_ORDER (NO_W_ID, NO_D_ID," -" NO_O_ID);" - ; - - str2 = - -" CREATE TABLE ORDERS (O_ID INT, O_D_ID CHAR, O_W_ID CHAR," -" O_C_ID CHAR," -" O_ENTRY_D INT," -" O_CARRIER_ID INT," -" O_OL_CNT INT," -" O_ALL_LOCAL CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX O_IND ON ORDERS (O_W_ID, O_D_ID," -" O_ID);" -" CREATE INDEX O_C_IND ON ORDERS (O_W_ID, O_D_ID, O_C_ID);" -"" -" CREATE TABLE ORDER_LINE (OL_O_ID INT, OL_D_ID CHAR, OL_W_ID CHAR," -" OL_NUMBER CHAR," -" OL_I_ID CHAR," -" OL_SUPPLY_W_ID CHAR," -" OL_DELIVERY_D INT," -" OL_QUANTITY INT," -" OL_AMOUNT INT," -" OL_DIST_INFO CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX OL_IND ON ORDER_LINE" -" (OL_W_ID, OL_D_ID, OL_O_ID, OL_NUMBER);" -"" -" CREATE TABLE ITEM (I_ID CHAR, I_IM_ID CHAR, I_NAME CHAR," -" I_PRICE INT," -" I_DATA CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX I_IND ON ITEM (I_ID);" -"" -" CREATE TABLE STOCK (S_I_ID CHAR," -" S_W_ID CHAR," -" S_QUANTITY INT," -" S_DIST_01 CHAR," -" S_DIST_02 CHAR," -" S_DIST_03 CHAR," -" S_DIST_04 CHAR," -" S_DIST_05 CHAR," -" S_DIST_06 CHAR," -" S_DIST_07 CHAR," -" S_DIST_08 CHAR," -" S_DIST_09 CHAR," -" S_DIST_10 CHAR," -" S_YTD INT," -" S_ORDER_CNT INT," -" S_REMOTE_CNT INT," -" S_DATA CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX S_IND ON STOCK (S_W_ID, S_I_ID);" -" END;" - ; - - str = ut_str_catenate(str1, str2); - - query = pars_sql(str); - - mem_free(str); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - /*-----------------------------------------------------------*/ - printf("\n\nPopulate TPC-C tables\n\n"); - - str1 = - -" PROCEDURE POPULATE_TABLES () IS" -"" -" i INT;" -" j INT;" -" k INT;" -" t INT;" -" string CHAR;" -" rnd1 INT;" -" rnd2 INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -"" -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 200;" -"" -" PRINTF('Starting to populate ITEMs');" -"" -" FOR i IN 1 .. n_items LOOP" -" rnd1 := RND(26, 50);" -" string := RND_STR(rnd1);" -"" -" IF (RND(0, 9) = 0) THEN" -" rnd2 := RND(0, rnd1 - 8);" -" REPLSTR(string, 'ORIGINAL', rnd2, 8);" -" COMMIT WORK;" -" END IF;" -"" -" INSERT INTO ITEM VALUES (TO_BINARY(i, 3)," -" TO_BINARY(RND(1, 10000), 3)," -" RND_STR(RND(14, 24))," -" RND(100, 10000)," -" string);" -" END LOOP;" -"" -" FOR i IN 1 .. n_warehouses LOOP" -" PRINTF('Starting to populate warehouse number ', i);" -" INSERT INTO WAREHOUSE VALUES (TO_BINARY(i, 2)," -" RND_STR(RND(6, 10))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(2)," -" CONCAT(SUBSTR(TO_CHAR(RND(0, 9999))," -" 6, 4)," -" '11111')," -" RND(0, 2000)," -" 0," -" 0);" -" FOR j IN 1 .. n_items LOOP" -"" -" rnd1 := RND(26, 50);" -" string := RND_STR(rnd1);" -"" -" IF (RND(0, 9) = 0) THEN" -" rnd2 := RND(0, rnd1 - 8);" -" REPLSTR(string, 'ORIGINAL', rnd2, 8);" -" COMMIT WORK;" -" END IF; " -"" -" INSERT INTO STOCK VALUES (TO_BINARY(j, 3)," -" TO_BINARY(i, 2)," -" RND(10, 100)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" 0, 0, 0," -" string);" -" END LOOP;" - ; - - str2 = -" FOR j IN 1 .. n_districts LOOP" -"" -" COMMIT WORK;" -" PRINTF('Starting to populate district number ', j);" -" INSERT INTO DISTRICT VALUES (TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" RND_STR(RND(6, 10))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(2)," -" CONCAT(SUBSTR(" -" TO_CHAR(RND(0, 9999))," -" 6, 4)," -" '11111')," -" RND(0, 2000)," -" 0," -" 0," -" 3001);" -"" -" FOR k IN 1 .. n_customers LOOP" -"" -" string := 'GC';" -"" -" IF (RND(0, 9) = 7) THEN" -" COMMIT WORK;" -" string := 'BC';" -" END IF;" -" " -" INSERT INTO CUSTOMER VALUES (" -" TO_BINARY(k, 3)," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" RND_STR(RND(8, 16))," -" 'OE'," -" CONCAT('NAME'," -" TO_CHAR(k / 3))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(2)," -" CONCAT(SUBSTR(" -" TO_CHAR(RND(0, 9999))," -" 6, 4)," -" '11111')," -" RND_STR(16)," -" SYSDATE(), 0," -" string," -" 0, 5000000," -" RND(0, 5000)," -" 0, 0, 0, 0, 0, 0," -" RND_STR(RND(300, 500)));" - ; - - str3 = -" INSERT INTO HISTORY VALUES (" -" TO_BINARY(k, 3)," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" SYSDATE()," -" 1000," -" RND_STR(RND(12, 24)));" -"" -" rnd1 := RND(5, 15);" -"" -" INSERT INTO ORDERS VALUES (" -" k," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" TO_BINARY(k, 3)," -" SYSDATE()," -" RND(1, 10)," -" rnd1," -" '1');" -"" -" FOR t IN 1 .. rnd1 LOOP" -" INSERT INTO ORDER_LINE VALUES (" -" k," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" TO_BINARY(t, 1)," -" TO_BINARY(" -" RND(0, n_items - 1)," -" 3)," -" TO_BINARY(i, 2)," -" SYSDATE()," -" RND(0, 99)," -" RND(0, 9999)," -" RND_STR(24));" -" END LOOP;" -" END LOOP;" -" " -" FOR k IN (2 * n_customers) / 3 .. n_customers LOOP" -" " -" INSERT INTO NEW_ORDER VALUES (" -" k," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2));" -" END LOOP;" -" END LOOP;" -" END LOOP; " -" " -" COMMIT WORK;" -" END;" - ; - - str4 = ut_str_catenate(str1, str2); - str = ut_str_catenate(str4, str3); - - query = pars_sql(str); - - mem_free(str); - mem_free(str4); - - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE PRINT_TABLES () IS" -" BEGIN" -"" -" /* PRINTF('Printing ITEM table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM ITEM;" -"" -" PRINTF('Printing WAREHOUSE table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM WAREHOUSE;" -"" -" PRINTF('Printing STOCK table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM STOCK;" -"" -" PRINTF('Printing DISTRICT table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM DISTRICT;" -"" -" PRINTF('Printing CUSTOMER table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM CUSTOMER;" -"" -" PRINTF('Printing HISTORY table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM HISTORY;" -"" -" PRINTF('Printing ORDERS table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM ORDERS;" -"" -" PRINTF('Printing ORDER_LINE table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM ORDER_LINE" -" WHERE OL_O_ID >= 3000; */" -"" -" PRINTF('Printing NEW_ORDER table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM NEW_ORDER;" -"" -" COMMIT WORK;" -" END;" - ; - - print_query = pars_sql(str); - - /*-----------------------------------------------------------*/ - commit_query = pars_sql( - -" PROCEDURE COMMIT_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ); - - - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE NEW_ORDER () IS" -"" -" i INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" w_tax INT;" -" c_w_id CHAR;" -" c_d_id CHAR;" -" c_id CHAR;" -" c_discount INT;" -" c_last CHAR;" -" c_credit CHAR;" -" d_tax INT;" -" o_id INT;" -" o_ol_cnt INT;" -" ol_i_id CHAR;" -" o_entry_d INT;" -" o_all_local CHAR;" -" i_price INT;" -" i_name CHAR;" -" i_data CHAR;" -" s_quantity INT;" -" s_data CHAR;" -" s_dist_01 CHAR;" -" s_dist_02 CHAR;" -" s_dist_03 CHAR;" -" s_dist_04 CHAR;" -" s_dist_05 CHAR;" -" s_dist_06 CHAR;" -" s_dist_07 CHAR;" -" s_dist_08 CHAR;" -" s_dist_09 CHAR;" -" s_dist_10 CHAR;" -" bg CHAR;" -" ol_quantity INT;" -" ol_amount INT;" -" ol_supply_w_id CHAR;" -" ol_dist_info CHAR;" -" total INT;" -"" -" DECLARE CURSOR district_cursor IS" -" SELECT D_NEXT_O_ID, D_TAX" -" FROM DISTRICT" -" WHERE D_ID = c_d_id AND D_W_ID = c_w_id" -" FOR UPDATE;" -"" -" DECLARE CURSOR stock_cursor IS" -" SELECT S_QUANTITY, S_DATA," -" S_DIST_01, S_DIST_02, S_DIST_03, S_DIST_04," -" S_DIST_05, S_DIST_06, S_DIST_07, S_DIST_08," -" S_DIST_09, S_DIST_10" -" FROM STOCK" -" WHERE S_W_ID = ol_supply_w_id AND S_I_ID = ol_i_id" -" FOR UPDATE;" - ; - str2 = - -" BEGIN" -" " -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 200;" -" " -" c_w_id := TO_BINARY(RND(1, n_warehouses), 2);" -" c_d_id := TO_BINARY(RND(1, n_districts) + 47, 1);" -" c_id := TO_BINARY(RND(1, n_customers), 3);" -"" -" o_ol_cnt := RND(5, 15);" -" o_all_local := '1';" -" bg := 'GGGGGGGGGGGGGGG';" -" total := 0;" -" " -" SELECT W_TAX INTO w_tax" -" FROM WAREHOUSE" -" WHERE W_ID = c_w_id;" -"" -" OPEN district_cursor;" -"" -" FETCH district_cursor INTO o_id, d_tax;" -"" -" /* PRINTF('C-warehouse id ', BINARY_TO_NUMBER(c_w_id)," -" ' C-district id ', c_d_id," -" ' order id ', o_id, ' linecount ', o_ol_cnt); */" -"" -" UPDATE DISTRICT SET D_NEXT_O_ID = o_id + 1" -" WHERE CURRENT OF district_cursor;" -"" -" CLOSE district_cursor;" -"" -" SELECT C_DISCOUNT, C_LAST, C_CREDIT INTO c_discount, c_last, c_credit" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id AND C_ID = c_id;" -"" - ; - str3 = - -" FOR i IN 1 .. o_ol_cnt LOOP" -"" -" ol_i_id := TO_BINARY(RND(1, n_items), 3);" -"" -" ol_supply_w_id := c_w_id;" -"" -" ol_quantity := RND(1, 10);" -"" -" SELECT I_PRICE, I_NAME, I_DATA INTO i_price, i_name, i_data" -" FROM ITEM" -" WHERE I_ID = ol_i_id;" -"" -" IF (SQL % NOTFOUND) THEN" -" PRINTF('Rolling back');" -" ROLLBACK WORK;" -"" -" RETURN;" -" END IF;" -"" -" OPEN stock_cursor;" -"" -" FETCH stock_cursor INTO s_quantity, s_data," -" s_dist_01, s_dist_02, s_dist_03," -" s_dist_04, s_dist_05, s_dist_06," -" s_dist_07, s_dist_08, s_dist_09," -" s_dist_10;" -"" -" IF (s_quantity >= ol_quantity + 10) THEN" -" s_quantity := s_quantity - ol_quantity;" -" ELSE" -" s_quantity := (s_quantity + 91) - ol_quantity;" -" END IF;" -"" -" UPDATE STOCK SET S_QUANTITY = s_quantity," -" S_YTD = S_YTD + ol_quantity," -" S_ORDER_CNT = S_ORDER_CNT + 1" -" WHERE CURRENT OF stock_cursor;" -"" -" IF (ol_supply_w_id <> c_w_id) THEN" -"" -" o_all_local := '0';" -" PRINTF('Remote order '," -" BINARY_TO_NUMBER(ol_supply_w_id), ' '," -" BINARY_TO_NUMBER(c_w_id));" -"" -" UPDATE STOCK SET S_REMOTE_CNT = S_REMOTE_CNT + 1" -" WHERE CURRENT OF stock_cursor;" -" END IF;" -"" -" CLOSE stock_cursor;" -"" -" IF ((INSTR(i_data, 'ORIGINAL') > 0)" -" OR (INSTR(s_data, 'ORIGINAL') > 0)) THEN" -" REPLSTR(bg, 'B', i - 1, 1);" -" END IF;" -"" -" ol_amount := ol_quantity * i_price;" -"" -" total := total + ol_amount;" - ; - str4 = -" IF (c_d_id = '0') THEN" -" ol_dist_info := s_dist_01;" -" ELSIF (c_d_id = '1') THEN" -" ol_dist_info := s_dist_02;" -" ELSIF (c_d_id = '2') THEN" -" ol_dist_info := s_dist_03;" -" ELSIF (c_d_id = '3') THEN" -" ol_dist_info := s_dist_04;" -" ELSIF (c_d_id = '4') THEN" -" ol_dist_info := s_dist_05;" -" ELSIF (c_d_id = '5') THEN" -" ol_dist_info := s_dist_06;" -" ELSIF (c_d_id = '6') THEN" -" ol_dist_info := s_dist_07;" -" ELSIF (c_d_id = '7') THEN" -" ol_dist_info := s_dist_08;" -" ELSIF (c_d_id = '8') THEN" -" ol_dist_info := s_dist_09;" -" ELSIF (c_d_id = '9') THEN" -" ol_dist_info := s_dist_10;" -" END IF;" -"" -" INSERT INTO ORDER_LINE VALUES (o_id, c_d_id, c_w_id," -" TO_BINARY(i, 1), ol_i_id," -" ol_supply_w_id, NULL, ol_quantity," -" ol_amount, ol_dist_info); " -" END LOOP;" -"" -" total := (((total * (10000 + w_tax + d_tax)) / 10000)" -" * (10000 - c_discount)) / 10000;" -"" -" o_entry_d := SYSDATE();" -"" -" INSERT INTO ORDERS VALUES (o_id, c_d_id, c_w_id, c_id, o_entry_d," -" NULL, o_ol_cnt, o_all_local);" -" INSERT INTO NEW_ORDER VALUES (o_id, c_d_id, c_w_id);" -"" -" /* PRINTF('Inserted order lines:');" -" ROW_PRINTF" -" SELECT * FROM ORDER_LINE WHERE OL_O_ID = o_id AND" -" OL_D_ID = c_d_id" -" AND OL_W_ID = c_w_id; */" -" /* COMMIT WORK; */" -" END;" - ; - - str5 = ut_str_catenate(str1, str2); - str6 = ut_str_catenate(str3, str4); - - str = ut_str_catenate(str5, str6); - - new_order_query = pars_sql(str); - - mem_free(str); - mem_free(str5); - mem_free(str6); - - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE PAYMENT () IS" -"" -" i INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" w_id CHAR;" -" w_street_1 CHAR;" -" w_street_2 CHAR;" -" w_city CHAR;" -" w_state CHAR;" -" w_zip CHAR;" -" w_name CHAR;" -" d_id CHAR;" -" d_street_1 CHAR;" -" d_street_2 CHAR;" -" d_city CHAR;" -" d_state CHAR;" -" d_zip CHAR;" -" d_name CHAR;" -" c_w_id CHAR;" -" c_d_id CHAR;" -" c_street_1 CHAR;" -" c_street_2 CHAR;" -" c_city CHAR;" -" c_state CHAR;" -" c_zip CHAR;" -" c_id CHAR;" -" c_last CHAR;" -" c_first CHAR;" -" c_middle CHAR;" -" c_phone CHAR;" -" c_credit CHAR;" -" c_credit_lim INT;" -" c_discount INT;" -" c_balance INT;" -" c_since INT;" -" c_data CHAR;" -" byname INT;" -" namecnt INT;" -" amount INT;" -" h_data CHAR;" -" h_date INT;" -" c_more_data CHAR;" -" more_len INT;" -" data_len INT;" -"" -" DECLARE CURSOR warehouse_cursor IS" -" SELECT W_STREET_1, W_STREET_2, W_CITY, W_STATE, W_ZIP, W_NAME" -" FROM WAREHOUSE" -" WHERE W_ID = w_id" -" FOR UPDATE;" -"" -" DECLARE CURSOR district_cursor IS" -" SELECT D_STREET_1, D_STREET_2, D_CITY, D_STATE, D_ZIP, D_NAME" -" FROM DISTRICT" -" WHERE D_W_ID = w_id AND D_ID = d_id" -" FOR UPDATE;" -"" -" DECLARE CURSOR customer_by_name_cursor IS" -" SELECT C_ID" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last" -" ORDER BY C_FIRST ASC;" -"" -" DECLARE CURSOR customer_cursor IS" -" SELECT C_FIRST, C_MIDDLE, C_LAST, C_STREET_1, C_STREET_2," -" C_CITY, C_STATE, C_ZIP, C_PHONE, C_CREDIT," -" C_CREDIT_LIM, C_DISCOUNT, C_BALANCE," -" C_SINCE" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_ID = c_id" -" FOR UPDATE;" - ; - - str2 = - -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 200;" -"" -" byname := RND(1, 100);" -" amount := RND(1, 1000);" -" h_date := SYSDATE();" -" w_id := TO_BINARY(RND(1, n_warehouses), 2);" -" d_id := TO_BINARY(47 + RND(1, n_districts), 1);" -" c_w_id := TO_BINARY(RND(1, n_warehouses), 2);" -" c_d_id := TO_BINARY(47 + RND(1, n_districts), 1);" -"" -" OPEN warehouse_cursor;" -"" -" FETCH warehouse_cursor INTO w_street_1, w_street_2, w_city, w_state," -" w_zip, w_name;" -" UPDATE WAREHOUSE SET W_YTD = W_YTD + amount" -" WHERE CURRENT OF warehouse_cursor;" -"" -" CLOSE warehouse_cursor;" -"" -" OPEN district_cursor;" -"" -" FETCH district_cursor INTO d_street_1, d_street_2, d_city, d_state," -" d_zip, d_name;" -" UPDATE DISTRICT SET D_YTD = D_YTD + amount" -" WHERE CURRENT OF district_cursor;" -"" -" CLOSE district_cursor;" -"" -" IF (byname <= 60) THEN" -" c_last := CONCAT('NAME', TO_CHAR(RND(1, n_customers) / 3));" -"" -" SELECT COUNT(*) INTO namecnt" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last;" -" /* PRINTF('Payment trx: Customer name ', c_last," -" ' namecount ', namecnt); */" -" OPEN customer_by_name_cursor;" -"" -" FOR i IN 1 .. (namecnt + 1) / 2 LOOP" -" FETCH customer_by_name_cursor INTO c_id;" -" END LOOP;" -" /* ASSERT(NOT (customer_by_name_cursor % NOTFOUND)); */" -" " -" CLOSE customer_by_name_cursor;" -" ELSE" -" c_id := TO_BINARY(RND(1, n_customers), 3);" -" END IF;" - - ; - str3 = -"" -" /* PRINTF('Payment for customer ', BINARY_TO_NUMBER(c_w_id), ' '," -" c_d_id, ' ', BINARY_TO_NUMBER(c_id)); */" -" OPEN customer_cursor;" -"" -" FETCH customer_cursor INTO c_first, c_middle, c_last, c_street_1," -" c_street_2, c_city, c_state, c_zip," -" c_phone, c_credit, c_credit_lim," -" c_discount, c_balance, c_since;" -" c_balance := c_balance - amount;" -"" -" h_data := CONCAT(w_name, ' ', d_name);" -" " -" IF (c_credit = 'BC') THEN" -" /* PRINTF('Bad customer pays'); */" -"" -" SELECT C_DATA INTO c_data" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_ID = c_id;" -" c_more_data := CONCAT(" -" ' ', TO_CHAR(BINARY_TO_NUMBER(c_id))," -" ' ', c_d_id," -" ' ', TO_CHAR(BINARY_TO_NUMBER(c_w_id))," -" ' ', d_id," -" ' ', TO_CHAR(BINARY_TO_NUMBER(w_id))," -" TO_CHAR(amount)," -" TO_CHAR(h_date)," -" ' ', h_data);" -"" -" more_len := LENGTH(c_more_data);" -" data_len := LENGTH(c_data);" -" " -" IF (more_len + data_len > 500) THEN" -" data_len := 500 - more_len;" -" END IF;" -" " -" c_data := CONCAT(c_more_data, SUBSTR(c_data, 0, data_len));" -" " -" UPDATE CUSTOMER SET C_BALANCE = c_balance," -" C_PAYMENT_CNT = C_PAYMENT_CNT + 1," -" C_YTD_PAYMENT = C_YTD_PAYMENT + amount," -" C_DATA = c_data" -" WHERE CURRENT OF customer_cursor;" -" ELSE" -" UPDATE CUSTOMER SET C_BALANCE = c_balance," -" C_PAYMENT_CNT = C_PAYMENT_CNT + 1," -" C_YTD_PAYMENT = C_YTD_PAYMENT + amount" -" WHERE CURRENT OF customer_cursor;" -" END IF;" -"" -" CLOSE customer_cursor;" -" " -" INSERT INTO HISTORY VALUES (c_d_id, c_w_id, c_id, d_id, w_id," -" h_date, amount, h_data);" -" /* COMMIT WORK; */" -"" -" END;" - - ; - - str4 = ut_str_catenate(str1, str2); - str = ut_str_catenate(str4, str3); - - payment_query = pars_sql(str); - - mem_free(str); - mem_free(str4); - - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE ORDER_STATUS () IS" -"" -" i INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" d_id CHAR;" -" namecnt INT;" -" c_w_id CHAR;" -" c_d_id CHAR;" -" c_id CHAR;" -" c_last CHAR;" -" c_first CHAR;" -" c_middle CHAR;" -" c_balance INT;" -" byname INT;" -" o_id INT;" -" o_carrier_id CHAR;" -" o_entry_d INT;" -" ol_i_id CHAR;" -" ol_supply_w_id CHAR;" -" ol_quantity INT;" -" ol_amount INT;" -" ol_delivery_d INT;" -"" -" DECLARE CURSOR orders_cursor IS" -" SELECT O_ID, O_CARRIER_ID, O_ENTRY_D" -" FROM ORDERS" -" WHERE O_W_ID = c_w_id AND O_D_ID = c_d_id" -" AND O_C_ID = c_id" -" ORDER BY O_ID DESC;" -"" -" DECLARE CURSOR order_line_cursor IS" -" SELECT OL_I_ID, OL_SUPPLY_W_ID, OL_QUANTITY, OL_AMOUNT," -" OL_DELIVERY_D" -" FROM ORDER_LINE" -" WHERE OL_W_ID = c_w_id AND OL_D_ID = c_d_id" -" AND OL_O_ID = o_id;" -" DECLARE CURSOR customer_by_name_cursor IS" -" SELECT C_ID" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last" -" ORDER BY C_FIRST ASC;" -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 200;" -"" -" c_w_id := TO_BINARY(RND(1, n_warehouses), 2);" -" byname := RND(1, 100);" -"" - ; - - str2 = - -" IF (byname <= 60) THEN" -" d_id := TO_BINARY(47 + RND(1, n_districts), 1); " -"" -" c_d_id := d_id;" -"" -" c_last := CONCAT('NAME', TO_CHAR(RND(1, n_customers) / 3));" -"" -" SELECT COUNT(*) INTO namecnt" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last;" -" OPEN customer_by_name_cursor;" -"" -" /* PRINTF('Order status trx: Customer name ', c_last," -" ' namecount ', namecnt); */" -" FOR i IN 1 .. (namecnt + 1) / 2 LOOP" -" FETCH customer_by_name_cursor INTO c_id;" -" END LOOP;" -" /* ASSERT(NOT (customer_by_name_cursor % NOTFOUND)); */" -"" -" CLOSE customer_by_name_cursor;" -" ELSE" -" c_d_id := TO_BINARY(47 + RND(1, n_districts), 1);" -" c_id := TO_BINARY(RND(1, n_customers), 3);" -" END IF;" -"" -" SELECT C_BALANCE, C_FIRST, C_MIDDLE, C_LAST INTO c_balance, c_first," -" c_middle, c_last" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id AND C_ID = c_id;" -"" -" OPEN orders_cursor;" -"" -" FETCH orders_cursor INTO o_id, o_carrier_id, o_entry_d;" -"" -" IF (orders_cursor % NOTFOUND) THEN" -" PRINTF('Order status trx: customer has no order');" -" CLOSE orders_cursor;" -"" -" /* COMMIT WORK; */" -"" -" RETURN;" -" END IF;" -"" -" CLOSE orders_cursor;" -"" -" OPEN order_line_cursor;" -"" -" FOR i IN 0 .. 15 LOOP" -" FETCH order_line_cursor INTO ol_i_id, ol_supply_w_id," -" ol_quantity, ol_amount," -" ol_delivery_d;" -"" -" IF (order_line_cursor % NOTFOUND) THEN" -" CLOSE order_line_cursor;" -"" -" /* COMMIT WORK; */" -"" -" RETURN;" -" END IF;" -" END LOOP;" -" ASSERT(0 = 1);" -" " -" END;" - ; - - str = ut_str_catenate(str1, str2); - - order_status_query = pars_sql(str); - - mem_free(str); - - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE DELIVERY () IS" -"" -" i INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" d_id CHAR;" -" w_id CHAR;" -" c_id CHAR;" -" o_id INT;" -" o_carrier_id INT;" -" ol_delivery_d INT;" -" ol_total INT;" -"" -" DECLARE CURSOR new_order_cursor IS" -" SELECT NO_O_ID" -" FROM NEW_ORDER" -" WHERE NO_W_ID = w_id AND NO_D_ID = d_id" -" ORDER BY NO_O_ID ASC;" -"" -" DECLARE CURSOR orders_cursor IS" -" SELECT O_C_ID" -" FROM ORDERS" -" WHERE O_W_ID = w_id AND O_D_ID = d_id" -" AND O_ID = o_id" -" FOR UPDATE;" -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 200;" -"" -" w_id := TO_BINARY(RND(1, n_warehouses), 2);" -" o_carrier_id := RND(1, 10);" -" ol_delivery_d := SYSDATE();" - - ; - - str2 = - -" FOR i IN 1 .. n_districts LOOP" -"" -" d_id := TO_BINARY(47 + i, 1);" -"" -" OPEN new_order_cursor;" -"" -" FETCH new_order_cursor INTO o_id;" -"" -" IF (new_order_cursor % NOTFOUND) THEN" -" /* PRINTF('No order to deliver'); */" -"" -" CLOSE new_order_cursor;" -" ELSE" -" CLOSE new_order_cursor;" -" /* PRINTF('Order to deliver'); */" -"" -" DELETE FROM NEW_ORDER" -" WHERE NO_W_ID = w_id AND NO_D_ID = d_id" -" AND NO_O_ID = o_id;" -" OPEN orders_cursor;" -"" -" FETCH orders_cursor INTO c_id;" -"" -" UPDATE ORDERS SET O_CARRIER_ID = o_carrier_id" -" WHERE CURRENT OF orders_cursor;" -"" -" CLOSE orders_cursor;" -"" -" UPDATE ORDER_LINE SET OL_DELIVERY_D = ol_delivery_d" -" WHERE OL_W_ID = w_id AND OL_D_ID = d_id" -" AND OL_O_ID = o_id;" -"" -" SELECT SUM(OL_AMOUNT) INTO ol_total" -" FROM ORDER_LINE" -" WHERE OL_W_ID = w_id AND OL_D_ID = d_id" -" AND OL_O_ID = o_id;" -"" -" UPDATE CUSTOMER SET C_BALANCE = C_BALANCE - ol_total" -" WHERE C_W_ID = w_id AND C_D_ID = d_id" -" AND C_ID = c_id;" -" END IF;" -" END LOOP;" -"" -" /* COMMIT WORK; */" -" " -" END;" - ; - - str = ut_str_catenate(str1, str2); - - delivery_query = pars_sql(str); - - mem_free(str); - - /*-----------------------------------------------------------*/ - - /* NOTE: COUNT(DISTINCT ...) not implemented yet */ - - str = - -" PROCEDURE STOCK_LEVEL () IS" -"" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" d_id CHAR;" -" w_id CHAR;" -" o_id INT;" -" stock_count INT;" -" threshold INT;" -"" -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 200;" -"" -" w_id := TO_BINARY(RND(1, n_warehouses), 2);" -" d_id := TO_BINARY(47 + 4, 1);" -"" -" threshold := RND(10, 20);" -"" -" SELECT D_NEXT_O_ID INTO o_id" -" FROM DISTRICT" -" WHERE D_W_ID = w_id AND D_ID = d_id;" -"" -" SELECT COUNT(*) INTO stock_count" -" FROM ORDER_LINE, STOCK" -" WHERE OL_W_ID = w_id AND OL_D_ID = d_id" -" AND OL_O_ID >= o_id - 20 AND OL_O_ID < o_id" -" AND S_W_ID = w_id AND S_I_ID = OL_I_ID" -" AND S_QUANTITY < threshold;" -" /* PRINTF(stock_count, ' items under threshold ', threshold); */" -" /* COMMIT WORK; */" -"" -" END;" - ; - - stock_level_query = pars_sql(str); - /*-----------------------------------------------------------*/ - - oldtm = ut_clock(); - - for (i = 0; i < 10; i++) { - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(new_order_query, - SESS_COMM_EXECUTE, 0); - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(payment_query, - SESS_COMM_EXECUTE, 0); - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 10 == 3) { - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(order_status_query, - SESS_COMM_EXECUTE, 0); - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - if ((i % 10 == 6) || (i % 100 == 60)) { - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(delivery_query, - SESS_COMM_EXECUTE, 0); - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - if (i % 10 == 9) { - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(stock_level_query, - SESS_COMM_EXECUTE, 0); - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - if ((i > 0) && (i % 200 == 0)) { - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(commit_query, - SESS_COMM_EXECUTE, 0); - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - return(0); -} - -#ifdef notdefined - -/********************************************************************* -General test. */ - -ulint -test1( -/*==*/ - void* arg) -{ - sess_t* sess; - sess_t* sess2; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* query; - que_thr_t* thr; - trx_t* trx; - trx_t* trx2; - ulint tm, oldtm; - ulint j; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1. GENERAL TEST\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - sess2 = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user2", 6); - - trx = sess->trx; - trx2 = sess2->trx; - - mutex_exit(&kernel_mutex); - - /*------------------------------------------------------*/ - query = pars_sql( -" PROCEDURE CREATE_TABLE () IS" -" BEGIN" -" CREATE TABLE TS_TABLE1 (COL1 CHAR, COL2 CHAR, COL3 CHAR);" -" CREATE TABLE TS_TABLE2 (COL21 INT, COL22 INT, COL23 CHAR);" -" CREATE TABLE TS_TABLE3 (COL31 INT, COL32 INT, COL33 CHAR);" -" CREATE TABLE TS_TABLE4 (COL41 INT, COL42 INT, COL43 CHAR);" -" CREATE UNIQUE CLUSTERED INDEX IND1 ON TS_TABLE1 (COL1);" -" CREATE UNIQUE CLUSTERED INDEX IND21 ON TS_TABLE2 (COL21);" -" CREATE UNIQUE CLUSTERED INDEX IND31 ON TS_TABLE3 (COL31);" -" CREATE CLUSTERED INDEX IND41 ON TS_TABLE4 (COL41);" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - - printf("Will start insert test\n"); - - query = pars_sql( - -" PROCEDURE INSERT_SPEED_TEST () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" int2 := 0;" -" int1 := 0;" -" WHILE int1 < 40 LOOP" -" INSERT INTO TS_TABLE2 VALUES (int1, int1 - 100 * (int1 / 100)," -" '123456789012345678901234567890');" -" int1 := int1 + 1;" -" " -" END LOOP;" -" " -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for insert test %lu milliseconds\n", tm - oldtm); - - - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE COMMIT_SPEED_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE2"); */ - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - printf("Will start insert test2\n"); - - query = pars_sql( - -" PROCEDURE INSERT_SPEED_TEST2 () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" INSERT INTO TS_TABLE3 SELECT * FROM TS_TABLE2;" -" " -" " -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for insert test2 %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE COMMIT_SPEED_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE2"); */ - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ -/* os_thread_sleep(1000000); */ - -/* btr_search_table_print_info("TS_TABLE3"); */ - - query = pars_sql( - -" PROCEDURE JOIN_SPEED_TEST () IS" -" int1 INT;" -" " -" BEGIN" -" SELECT COUNT(*) INTO int1" -" FROM TS_TABLE2, TS_TABLE3" -" WHERE COL21 = COL31" -" CONSISTENT READ;" -" PRINTF(int1);" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - for (j = 0; j < 20; j++) { - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, - 0)); - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - - printf("Wall time for join test %lu milliseconds\n", - tm - oldtm); - } - -/* btr_search_table_print_info("TS_TABLE3"); */ - - /*------------------------------------------------------*/ - printf("Will start update test\n"); - - os_thread_sleep(2000000); - - query = pars_sql( - -" PROCEDURE UPDATE_SPEED_TEST () IS" -" int1 INT;" -" BEGIN" -" UPDATE TS_TABLE2 SET COL22 = COL22 + 1;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for update test %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE COMMIT_SPEED_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE2"); */ - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - printf("Will start TPC-A\n"); - os_thread_sleep(2000000); - - query = pars_sql( -" PROCEDURE TPC_A_SPEED_TEST () IS" -" int1 INT;" -" " -" BEGIN" -" int1 := 0;" -" WHILE int1 < 1000 LOOP" -" INSERT INTO TS_TABLE4 VALUES (int1, int1," -" '123456789012345678901234567890');" -" UPDATE TS_TABLE2 SET COL22 = COL22 + 1" -" WHERE COL21 = int1;" -" UPDATE TS_TABLE2 SET COL22 = COL22 + 1" -" WHERE COL21 = int1 + 1;" -" UPDATE TS_TABLE2 SET COL22 = COL22 + 1" -" WHERE COL21 = int1 + 2;" -" int1 := int1 + 1;" -" END LOOP;" -" " -" END;" - ); - -/*" SELECT COUNT(*) INTO int1 FROM TS_TABLE2 WHERE COL22 = COL21 + 4;" -" PRINTF(int1);" -" SELECT COUNT(*) INTO int1 FROM TS_TABLE4;" -" PRINTF(int1);" -*/ - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for TPC-A test %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE COMMIT_SPEED_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - printf("Will start insert test\n"); - - os_thread_sleep(2000000); - - query = pars_sql( - -" PROCEDURE INSERT_SPEED_TEST () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" int2 := 0;" -" int1 := 0;" -" WHILE int1 < 1000 LOOP" -" INSERT INTO TS_TABLE2 VALUES (int1, int1," -" '123456789012345678901234567890');" -" int1 := int1 + 1;" -" " -" END LOOP;" -" SELECT COUNT(*) INTO int2" -" FROM TS_TABLE2;" -" ASSERT(int1 = int2);" -" " -" COMMIT WORK;" -" " -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for insert test %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE DELETE_SPEED_TEST () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" SELECT COUNT(*), SUM(COL22) INTO int1, int2" -" FROM TS_TABLE2" -" CONSISTENT READ;" -" ASSERT(int1 = 1000);" -" ASSERT(int2 = 999 * 500);" -" DELETE FROM TS_TABLE2;" -" " -" SELECT COUNT(*), SUM(COL22) INTO int1, int2" -" FROM TS_TABLE2" -" CONSISTENT READ;" -" ASSERT(int1 = 0);" -" ASSERT(int2 = 0);" -" " -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for delete test %lu milliseconds\n", tm - oldtm); - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - os_thread_sleep(2000000); - - query = pars_sql( - -" PROCEDURE CONSISTENT_READ_TEST () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" SELECT COUNT(*), SUM(COL22) INTO int1, int2" -" FROM TS_TABLE2" -" CONSISTENT READ;" -" ASSERT(int2 = 999 * 500);" -" ASSERT(int1 = 1000);" -" " -" " -" END;" - ); - - query->trx = trx2; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for consistent read test %lu milliseconds\n", - tm - oldtm); - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE ROLLBACK_SPEED_TEST () IS" -" " -" BEGIN" -" ROLLBACK WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE UPDATE_SPEED_TEST () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" UPDATE TS_TABLE2 SET COL21 = COL21 + 1000, COL22 = COL22 + 1" -" WHERE COL21 < 1000;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" UPDATE TS_TABLE2 SET COL21 = COL21, COL22 = COL22;" -" " -" SELECT SUM(COL21), SUM(COL22) INTO int1, int2" -" FROM TS_TABLE2" -" CONSISTENT READ;" -" ASSERT(int2 = 1000 + 999 * 500);" -" ASSERT(int1 = 1000000 + 999 * 500);" -" UPDATE TS_TABLE2 SET COL21 = COL21 + 1000, COL22 = COL22 + 1" -" WHERE COL21 < 2000;" -" UPDATE TS_TABLE2 SET COL21 = COL21 + 1000, COL22 = COL22 + 1" -" WHERE COL21 < 3000;" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for update test %lu milliseconds\n", tm - oldtm); - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - os_thread_sleep(2000000); - - query = pars_sql( - -" PROCEDURE CONSISTENT_READ_TEST () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" SELECT COUNT(*), SUM(COL22) INTO int1, int2" -" FROM TS_TABLE2" -" CONSISTENT READ;" -" ASSERT(int1 = 1000);" -" ASSERT(int2 = 999 * 500);" -" " -" " -" END;" - ); - - query->trx = trx2; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for consistent read test %lu milliseconds\n", - tm - oldtm); - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE COMMIT_SPEED_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE2"); */ - /*------------------------------------------------------*/ - /*------------------------------------------------------*/ - os_thread_sleep(2000000); - - query = pars_sql( - -" PROCEDURE CONSISTENT_READ_TEST () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" SELECT COUNT(*), SUM(COL22) INTO int1, int2" -" FROM TS_TABLE2" -" CONSISTENT READ;" -" ASSERT(int1 = 1000);" -" ASSERT(int2 = 999 * 500);" -" " -" " -" END;" - ); - - query->trx = trx2; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for consistent read test %lu milliseconds\n", - tm - oldtm); - /*------------------------------------------------------*/ - printf("Will start insert test2\n"); - os_thread_sleep(2000000); - - query = pars_sql( - -" PROCEDURE INSERT_SPEED_TEST2 () IS" -" int1 INT;" -" int2 INT;" -" " -" BEGIN" -" INSERT INTO TS_TABLE3 SELECT * FROM TS_TABLE2;" -" " -" SELECT COUNT(*) INTO int1" -" FROM TS_TABLE2;" -" SELECT COUNT(*) INTO int2" -" FROM TS_TABLE3;" -" ASSERT(int1 = int2);" -" " -" COMMIT WORK;" -" " -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for insert test2 %lu milliseconds\n", tm - oldtm); - -/* sync_print(); */ - - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE COMMIT_SPEED_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - - query = pars_sql( - -" PROCEDURE JOIN_SPEED_TEST () IS" -" int1 INT;" -" " -" BEGIN" -" SELECT COUNT(*) INTO int1" -" FROM TS_TABLE2, TS_TABLE3" -" WHERE COL21 = COL31;" -" ASSERT(int1 = 1000);" -" " -" COMMIT WORK;" -" " -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for join test %lu milliseconds\n", tm - oldtm); - - /*------------------------------------------------------*/ - - dict_table_print_by_name("TS_TABLE1"); - dict_table_print_by_name("TS_TABLE2"); - -/* - dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); - dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); -*/ - query = pars_sql( - -" PROCEDURE INSERT_TEST () IS" -" var1 CHAR;" -" var2 CHAR;" -" int1 INT;" -" int2 INT;" -" sum1 INT;" -" finished INT;" -" rnd_var1 INT;" -" rnd_var2 INT;" -" " -" DECLARE CURSOR cursor2" -" IS SELECT COL21, COL22" -" FROM TS_TABLE2" -" WHERE COL21 > 5;" -" " -" BEGIN" -" int1 := 0;" -" WHILE int1 < 10 LOOP" -" rnd_var1 := int1;" -" PRINTF('Round '); PRINTF(int1);" -" INSERT INTO TS_TABLE2 VALUES (int1, rnd_var1," -" '123456789012345678901234567890');" -" SELECT COL22 INTO rnd_var2 FROM TS_TABLE2" -" WHERE COL21 = int1;" -" ASSERT(rnd_var1 = rnd_var2);" -" int1 := int1 + 1;" -" END LOOP;" -" " -" PRINTF('First explicit cursor loop:');" -" OPEN cursor2;" -" finished := 0;" -" " -" WHILE finished = 0 LOOP" -" FETCH cursor2 INTO int1, int2;" -" IF cursor2 % NOTFOUND THEN" -" finished := 1;" -" PRINTF('Loop now finished');" -" ELSE" -" PRINTF('Row fetched, values:');" -" PRINTF(int1); PRINTF(int2);" -" ASSERT(int1 = int2);" -" UPDATE TS_TABLE2 SET COL22 = COL22 + 100" -" WHERE CURRENT OF cursor2;" -" END IF;" -" END LOOP;" -" CLOSE cursor2;" -" " -" PRINTF('Second explicit cursor loop:');" -" OPEN cursor2;" -" finished := 0;" -" " -" WHILE finished = 0 LOOP" -" FETCH cursor2 INTO int1, int2;" -" IF cursor2 % NOTFOUND THEN" -" finished := 1;" -" ELSE" -" PRINTF('Row fetched, values:');" -" PRINTF(int1); PRINTF(int2);" -" ASSERT(int1 + 100 = int2);" -" UPDATE TS_TABLE2 SET COL22 = int2 + 100" -" WHERE CURRENT OF cursor2;" -" END IF;" -" END LOOP;" -" CLOSE cursor2;" -" " -" SELECT COUNT(*), SUM(COL22) INTO int1, sum1" -" FROM TS_TABLE2;" -" PRINTF('Now table 2 has this many rows: '); PRINTF(int1);" -" PRINTF('and the sum of COL22: '); PRINTF(sum1);" -" " -" INSERT INTO TS_TABLE3" -" SELECT COL21, COL22 + 10, COL23 FROM TS_TABLE2;" -" " -" SELECT COUNT(*), SUM(COL32) INTO int1, sum1" -" FROM TS_TABLE2, TS_TABLE3" -" WHERE COL21 + 2 = COL31;" -" PRINTF('Join table has this many rows: '); PRINTF(int1);" -" PRINTF('and the sum of COL32: '); PRINTF(sum1);" -" " -" ROLLBACK WORK;" -" " -" SELECT COUNT(*), SUM(COL21) INTO int1, sum1 FROM TS_TABLE2;" -" PRINTF('Now table 2 has this many rows: '); PRINTF(int1);" -" PRINTF('and the sum of COL21: '); PRINTF(sum1);" -" " -" " -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("TS_TABLE1"); - dict_table_print_by_name("TS_TABLE2"); - - query = pars_sql( - -" PROCEDURE DELETE_TEST () IS" -" int1 INT;" -" sum1 INT;" -" finished INT;" -" " -" DECLARE CURSOR cursor2" -" IS SELECT" -" FROM TS_TABLE2" -" WHERE COL21 < 10;" -" " -" BEGIN" -" int1 := 0;" -" WHILE int1 < 10 LOOP" -" PRINTF('Round '); PRINTF(int1);" -" INSERT INTO TS_TABLE2 VALUES (int1, int1, TO_CHAR(int1));" -" int1 := int1 + 1;" -" END LOOP;" -" COMMIT WORK;" -" PRINTF('Delete all the rows:');" -" OPEN cursor2;" -" finished := 0;" -" " -" WHILE finished = 0 LOOP" -" FETCH cursor2 INTO;" -" IF cursor2 % NOTFOUND THEN" -" finished := 1;" -" PRINTF('Loop now finished: all rows deleted');" -" ELSE" -" DELETE FROM TS_TABLE2" -" WHERE CURRENT OF cursor2;" -" END IF;" -" END LOOP;" -" CLOSE cursor2;" -" " -" SELECT COUNT(*), SUM(COL22) INTO int1, sum1" -" FROM TS_TABLE2;" -" PRINTF('Now table 2 has this many rows, and their sum is: ');" -" PRINTF(int1); PRINTF(sum1);" -" ASSERT((int1 = 0) AND (sum1 = 0));" -" " -" ROLLBACK WORK;" -" " -" SELECT COUNT(*), SUM(COL22) INTO int1, sum1" -" FROM TS_TABLE2;" -" " -" PRINTF(int1); PRINTF(sum1);" -" ASSERT((int1 = 10) AND (sum1 = 45));" -" COMMIT WORK;" -" DELETE FROM TS_TABLE2 WHERE COL22 = 5;" -" SELECT COUNT(*), SUM(COL22) INTO int1, sum1" -" FROM TS_TABLE2;" -" PRINTF(int1); PRINTF(sum1);" -" ASSERT((int1 = 9) AND (sum1 = 40));" -" DELETE FROM TS_TABLE2 WHERE COL23 = TO_CHAR(6);" -" SELECT COUNT(*), SUM(COL22) INTO int1, sum1" -" FROM TS_TABLE2;" -" PRINTF(int1);" -" PRINTF(sum1);" -" ASSERT((int1 = 8) AND (sum1 = 34));" -" DELETE FROM TS_TABLE2 WHERE COL23 = TO_CHAR(6);" -" SELECT COUNT(*), SUM(COL22) INTO int1, sum1" -" FROM TS_TABLE2;" -" PRINTF(int1);" -" PRINTF(sum1);" -" ASSERT((int1 = 8) AND (sum1 = 34));" -" COMMIT WORK;" -" END;" - ); - - query->trx = trx; - - thr = UT_LIST_GET_FIRST(query->thrs); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(query, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - return(0); -} - -#endif - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - oldtm = ut_clock(); - - test_c(NULL); - - tm = ut_clock(); - - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} - diff --git a/innobase/btr/ts/tsbtr97.c b/innobase/btr/ts/tsbtr97.c deleted file mode 100644 index 633fb7f22ae..00000000000 --- a/innobase/btr/ts/tsbtr97.c +++ /dev/null @@ -1,5080 +0,0 @@ -/************************************************************************ -Test for the B-tree - -(c) 1996-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "os0proc.h" -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "mem0pool.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "buf0flu.h" -#include "os0file.h" -#include "os0thread.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "log0recv.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "btr0cur.h" -#include "btr0sea.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "trx0purge.h" -#include "row0ins.h" -#include "row0upd.h" -#include "row0row.h" -#include "row0del.h" -#include "lock0lock.h" -#include "ibuf0ibuf.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 2 -#define N_FILES 1 -#define FILE_SIZE 512 /* must be > 512 */ -#define POOL_SIZE 500 -#define COUNTER_OFFSET 1500 - -#define N_LOG_GROUPS 2 -#define N_LOG_FILES 3 -#define LOG_FILE_SIZE 500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - -#define COUNT 1 - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -ulint dummy = 0; - -byte rnd_buf[256 * 256]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - ulint i; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - fil_aio_wait(segment); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates or opens the log files. */ - -void -create_log_files(void) -/*==================*/ -{ - bool ret; - ulint i, k; - char name[20]; - - printf("--------------------------------------------------------\n"); - printf("Create or open log files\n"); - - strcpy(name, "logfile00"); - - for (k = 0; k < N_LOG_GROUPS; k++) { - for (i = 0; i < N_LOG_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, OS_FILE_AIO, - &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_AIO, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - 8192 * LOG_FILE_SIZE, 0)); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k + 100, FIL_LOG); - } - - ut_a(fil_validate()); - - fil_node_create(name, LOG_FILE_SIZE, k + 100); - } - - fil_space_create(name, k + 200, FIL_LOG); - - log_group_init(k, N_LOG_FILES, LOG_FILE_SIZE * UNIV_PAGE_SIZE, - k + 100, k + 200); - } -} - -/************************************************************************* -Creates the files for the file system test and inserts them to the file -system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k, j, c; - char name[20]; - os_thread_t thr[10]; - os_thread_id_t id[10]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < 2 * N_SPACES; k += 2) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_NORMAL, &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_NORMAL, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - UNIV_PAGE_SIZE * FILE_SIZE, 0)); - /* Initialize the file contents to a random value */ - - for (j = 0; j < FILE_SIZE; j++) { - for (c = 0; c < UNIV_PAGE_SIZE; c++) { - rnd_buf[c] = 0xFF; - /*(byte) - (ut_rnd_gen_ulint() % 256); */ - } - - os_file_write(files[i], rnd_buf, - UNIV_PAGE_SIZE * j, 0, - UNIV_PAGE_SIZE); - } - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, FIL_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - mutex_set_level(&ios_mutex, SYNC_NO_ORDER_CHECK); - - for (i = 0; i < 9; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space headers of spaces 0 and 2. */ - -void -init_spaces(void) -/*=============*/ -{ - mtr_t mtr; - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - fsp_header_init(2, FILE_SIZE * N_FILES, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -Test for table creation. */ - -ulint -test1( -/*==*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND1", 0, - /*DICT_UNIQUE |*/ DICT_CLUSTERED, 1); - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -#ifdef notdefined - /*-------------------------------------*/ - /* CREATE YET ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND4", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -#endif -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_5( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.5. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE2", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE2", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_6( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.6. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE3", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE3", "IND1", 0, DICT_CLUSTERED, - 2); - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_7( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.7. CREATE TABLE WITH 12 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE4", 0, 12); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL4", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL5", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL6", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL7", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL8", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL9", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL10", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL11", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL12", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE4", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Test for inserts. */ - -ulint -test2( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - dict_index_t* index; -/* ulint size; */ - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2. MASSIVE INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - /* MASSIVE RANDOM INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 7857641) % 200000; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 100 == 0) { - printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); -/* - for (i = 0; i < 10; i++) { - size = ibuf_contract(TRUE); - - printf("%lu bytes will be contracted\n", size); - - os_thread_sleep(1000000); - } -*/ -/* index = dict_table_get_next_index(dict_table_get_first_index(table)); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - index = dict_table_get_next_index(index); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); -*/ -/* dict_table_print_by_name("TS_TABLE1"); */ - - btr_search_print_info(); - - /* Check inserted entries */ - - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < 1 /* *((ulint*)arg) */; i++) { - - rnd = (rnd + 7857641) % 200000; - dtuple_gen_search_tuple3(entry, rnd, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - -/* btr_validate_tree(tree); */ - -/* btr_print_tree(tree, 5); */ - -#ifdef notdefined - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - btr_validate_tree(tree); - -/* btr_search_print_info(); - dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_1( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ins_node_t* node; - ulint count = 0; - ulint rnd; - dtuple_t* row; -/* buf_frame_t* frame_table[2000]; - dict_tree_t* tree; - dict_index_t* index; - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; */ - - printf("-------------------------------------------------\n"); - printf("TEST 2.1. MASSIVE ASCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - rnd = 0; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 5000 == 0) { - - /* fsp_print(0); */ - /* ibuf_print(); */ - /* buf_print(); */ - - /* buf_print_io(); */ - - tm = ut_clock(); - /* - printf("Wall time for %lu inserts %lu milliseconds\n", - i, tm - oldtm); */ - } - - rnd = rnd + 1; - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined -/* dict_table_print_by_name("TS_TABLE1"); */ - - ibuf_print(); - - index = dict_table_get_first_index(table); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - /* Check inserted entries */ - - btr_search_print_info(); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ - /* ROLLBACK */ - -/* btr_validate_tree(tree); */ - - for (i = 0; i < POOL_SIZE - 1; i++) { - frame_table[i] = buf_frame_alloc(FALSE); - } - - for (i = 0; i < POOL_SIZE - 1; i++) { - buf_frame_free(frame_table[i]); - } - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); -#endif -#ifdef notdefined - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_search_print_info(); - -#endif - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - /*-------------------------------------*/ - - count++; -/* btr_validate_tree(tree); */ - - if (count < 1) { - goto loop; - } - - mem_heap_free(heap); - - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_2( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2. MASSIVE DESCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = *((ulint*)arg) + 1; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 200000; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND3500, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 1000 == 0) { -/* printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); */ - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i + 1, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_validate_tree(tree); -/* dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - btr_validate_tree(tree); - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Multithreaded test for random inserts. */ - -ulint -test2mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2MT. MULTITHREADED RANDOM INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - rnd = 78675; -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - if (i % 100 == 0) { - printf("*******Inserted %lu rows\n", i); -/* buf_print(); */ - ibuf_print(); - } - - rnd = (rnd + 7857641) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_1mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.1MT. MULTITHREADED ASCENDING INSERT\n"); - - rnd = 8757677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 98667501; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_2mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2MT. MULTITHREADED DESCENDING INSERT\n"); - - rnd = 87677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 78667; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - mem_print_info(); - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for updates. */ - -ulint -test3( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - byte* ptr; - ulint len; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 3. UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 3; i++) { - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* UPDATE ROWS */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - dtuple_gen_test_tuple3(row, 1, DTUPLE_TEST_RND30, buf); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - ut_a(DB_SUCCESS == lock_clust_rec_read_check_and_lock(0, - btr_pcur_get_rec(&pcur), - index, LOCK_X, thr)); - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), "updated field", 14); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - mtr_start(&mtr); - - ut_a(btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr)); - - ptr = rec_get_nth_field(btr_pcur_get_rec(&pcur), 5, &len); - - ut_a(ut_memcmp(ptr, "updated field", 14) == 0); - - btr_pcur_commit(&pcur); - - dict_table_print_by_name("TS_TABLE1"); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - dfield_set_data(&(ufield->new_val), "31415926", 9); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); -#ifdef notdefined - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ -#endif - dict_table_print_by_name("TS_TABLE1"); - count++; - - if (count < 1) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Init for update test. */ - -ulint -test4_1(void) -/*=========*/ -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - - printf("-------------------------------------------------\n"); - printf("TEST 4.1. UPDATE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/************************************************************************* -Checks that the multithreaded update test has rolled back its updates. */ - -void -test4_2(void) -/*=========*/ -{ - dtuple_t* entry; - mem_heap_t* heap; - mem_heap_t* heap2; - mtr_t mtr; - byte buf[32]; - sess_t* sess; - com_endpoint_t* com_endpoint; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - btr_pcur_t pcur; - rec_t* rec; - - printf("-------------------------------------------------\n"); - printf("TEST 4.2. CHECK UPDATE RESULT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*------------------------------------------*/ - - table = dict_table_get("TS_TABLE1", trx); - - index = dict_table_get_first_index(table); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < 200; i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - rec = btr_pcur_get_rec(&pcur); - - ut_a(0 == cmp_dtuple_rec(entry, rec)); - - heap2 = mem_heap_create(200); - - row = row_build(ROW_COPY_DATA, index, rec, heap2); - - ut_a(30 == dfield_get_len(dtuple_get_nth_field(row, 2))); - ut_a(0 == ut_memcmp( - dfield_get_data(dtuple_get_nth_field(row, 2)), - "12345678901234567890123456789", 30)); - - mem_heap_free(heap2); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -} - -/********************************************************************* -Test for massive updates. */ - -ulint -test4mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 4. MULTITHREADED UPDATES\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 999; i++) { - - rnd += 874681; - tuple_no = (rnd % 40) * 5 + thr_no; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("%lu: thread %lu to update row %lu\n", i, thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 200); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - if ((count == 1) && (thr_no != 4)) { - - return(0); - } - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(7000000); - - btr_validate_tree(tree); - - ut_a(trx->conc_state != TRX_ACTIVE); - ut_a(UT_LIST_GET_LEN(trx->trx_locks) == 0); - - count++; - - if (count < 2) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for join. */ - -ulint -test6( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ulint count = 0; - dtuple_t* entry; - dict_index_t* index; - dict_tree_t* tree; - btr_pcur_t pcur; - btr_pcur_t pcur2; - mtr_t mtr; - mtr_t mtr2; - ulint rnd; - ulint latch_mode; - - printf("-------------------------------------------------\n"); - printf("TEST 6. MASSIVE EQUIJOIN\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*--------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - /*--------------*/ - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - table = dict_table_get("TS_TABLE1", trx); - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - oldtm = ut_clock(); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IS, thr)); - - rnd = 98651; - - for (i = 0; i < *((ulint*)arg); i++) { - - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - btr_pcur_store_position(&pcur, &mtr); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); - - btr_pcur_commit_specify_mtr(&pcur, &mtr); - - if (i % 1211 == 0) { - dummy++; - } - - rnd = 55321; - - dtuple_gen_search_tuple3(entry, rnd % *((ulint*)arg), buf); - -/* if (i == 0) { */ - latch_mode = BTR_SEARCH_LEAF; -/* } else { - latch_mode = BTR_SEARCH_LEAF | BTR_GUESS_LATCH; - } */ - - mtr_start(&mtr2); - - btr_pcur_open(index, entry, PAGE_CUR_LE, latch_mode, - &pcur2, &mtr2); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur2), - index)); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur2))); - - mtr_commit(&mtr2); - - mtr_start(&mtr); - - btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - tm = ut_clock(); - printf("Wall time for join of %lu rows %lu milliseconds\n", - i, tm - oldtm); - btr_search_index_print_info(index); - /*-------------------------------------*/ - /* COMMIT */ - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); -/* printf("Wall time for commit %lu milliseconds\n", tm - oldtm); */ - - /*-------------------------------------*/ - count++; -/* btr_validate_tree(tree); */ - - if (count < 3) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for lock wait. Requires Test 4.1 first. */ - -ulint -test7( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - trx_t* trx2; - ulint rnd; - dtuple_t* entry; - dtuple_t* row; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 7. LOCK WAIT\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx2 = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - /* UPDATE by trx */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - ut_a(trx_start(trx2, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 2); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - rnd += 874681; - tuple_no = 3; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 1500); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - tm = ut_clock(); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* INSERT by trx2 */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx2; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx2); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx2->sess); - - trx2->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - dtuple_gen_test_tuple3(row, 2, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - /* Insert should be left to wait until trx releases the row lock */ - - que_run_threads(thr); - - tm = ut_clock(); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* COMMIT of trx */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - - /*-------------------------------------*/ - os_thread_sleep(1000000); - - printf( - "trx2 can now continue to do the insert, after trx committed.\n"); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/********************************************************************* -Inserts for TPC-A. */ - -ulint -test8A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 8A. 1000 INSERTS FOR TPC-A\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE2", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 1000; i++) { - dtuple_gen_test_tuple_TPC_A(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < 1000; i++) { - dtuple_gen_search_tuple_TPC_A(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE2"); */ - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for TPC-A transaction. */ - -ulint -test8( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 8. TPC-A %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE2", trx); - - update = upd_create(1, heap); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); - -loop: -/* printf("Round %lu\n", count); */ - - /*-------------------------------------*/ - /* INSERT */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - /*-------------------------------------*/ - /* 3 UPDATES */ - - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - - for (i = 0; i < 3; i++) { - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_A(entry, rnd % 1000, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - -/* ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); */ - -/* btr_pcur_store_position(&pcur, &mtr); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - tm = ut_clock(); - printf("Wall time for TPC-A %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ - - -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Inserts for TPC-C. */ - -ulint -test9A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; -/* dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - dict_index_t* index; - dict_tree_t* tree; -*/ - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 9A. INSERTS FOR TPC-C\n"); - -#define TPC_C_TABLE_SIZE 15000 - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE4", trx); - - row = dtuple_create(heap, 12 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_test_tuple_TPC_C(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_search_tuple_TPC_C(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); -#endif - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE4"); */ - -/* mem_heap_free(heap); */ - return(0); -} - -/********************************************************************* -Test for TPC-C transaction. Test 9A must be run first to populate table. */ - -ulint -test9( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint j; - ulint i; - byte* ptr; - ulint len; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - byte buf2[240]; - rec_t* rec; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 9. TPC-C %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE4", trx); - - update = upd_create(3, heap); - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 2); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); -loop: - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IS, thr)); - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - -/* printf("Round %lu\n", count); */ - -for (j = 0; j < 13; j++) { - - /*-------------------------------------*/ - /* SELECT FROM 'ITEM' */ - - rnd += 876751; - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_S, thr); - ut_a(err == DB_SUCCESS); - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 5; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* UPDATE 'STOCK' */ - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - -/* btr_pcur_store_position(&pcur, &mtr); */ - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 10; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - -/* btr_pcur_commit(&pcur); */ - -/* err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); */ - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); -/* ut_a(err == DB_SUCCESS); */ - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 1); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 2); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - btr_pcur_close(&pcur); - /*-------------------------------------*/ - /* INSERT INTO 'ORDERLINE' */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count * 13 + j, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -} - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - - tm = ut_clock(); - printf("Wall time for TPC-C %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Init for purge test. */ - -ulint -test10_1( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.1. PURGE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i * 100 + thr_no, - DTUPLE_TEST_FIXED30, buf); - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 200); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2_r( -/*=======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 2000); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(2000000); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_3( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.3. PURGE TEST DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - rnd = i; - tuple_no = rnd; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_5( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.5. PURGE TEST UNCOMMITTED DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 50; i++) { - - rnd = i; - tuple_no = rnd % 100; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - return(0); -} - -/********************************************************************* -Multithreaded test for purge. */ - -ulint -test10mt( -/*=====*/ - void* arg) -{ - ulint i; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("Thread %lu starts purge test\n", thr_no); - - for (i = 0; i < 2; i++) { - test10_1(arg); - - sync_print(); - - fsp_validate(0); - - test10_2_r(arg); - sync_print(); - - test10_2(arg); - sync_print(); - - lock_validate(); - - test10_3(arg); - sync_print(); - } - - printf("Thread %lu ends purge test\n", thr_no); - - return(0); -} - -/********************************************************************* -Purge test. */ - -ulint -test10_4( -/*=====*/ - void* arg) -{ - ulint i; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.4. PURGE TEST\n"); - - for (i = 0; i < 30; i++) { - trx_purge(); - - printf("%lu pages purged\n", purge_sys->n_pages_handled); - - os_thread_sleep(5000000); - } - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -This thread is used to test insert buffer merge. */ - -ulint -test_ibuf_merge( -/*============*/ - void* arg) -{ - ulint sum_sizes; - ulint volume; - - ut_ad(arg); - - printf("Starting ibuf merge\n"); - - sum_sizes = 0; - volume = 1; - - while (volume) { - volume = ibuf_contract(FALSE); - - sum_sizes += volume; - } - - printf("Ibuf merged %lu bytes\n", sum_sizes); - - os_thread_sleep(5000000); - - return(0); -} - -/********************************************************************* -This thread is used to measure contention of latches. */ - -ulint -test_measure_cont( -/*==============*/ - void* arg) -{ - ulint i, j; - ulint count; - - ut_ad(arg); - - printf("Starting contention measurement\n"); - - for (i = 0; i < 1000; i++) { - count = 0; - - for (j = 0; j < 100; j++) { - - os_thread_sleep(10000); - - if ((&(buf_pool->mutex))->lock_word) { - - count++; - } - } - - printf("Mutex reserved %lu of %lu peeks\n", count, j); - } - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - os_thread_id_t id[10]; - ulint n1000[10]; - ulint i; - ulint n5000 = 500; - ulint n2; - char buf[100]; - -/* buf_debug_prints = TRUE; */ - log_do_write = TRUE; - btr_search_use_hash = TRUE; - log_debug_writes = TRUE; - - srv_boot("initfile"); - os_aio_init(576, 9, 100); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - lock_sys_create(1024); - - create_files(); - create_log_files(); - - init_spaces(); - - sess_sys_init_at_db_start(); - - trx_sys_create(); - - dict_create(); - - log_make_checkpoint_at(ut_dulint_max); -/* log_debug_writes = TRUE; */ - -/* os_thread_sleep(500000); */ - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(NULL); -/* test1_5(NULL); - test1_6(NULL); - test1_7(NULL); */ - -/* for (i = 0; i < 2; i++) { - - n1000[i] = i; - id[i] = id[i]; - - os_thread_create(test10mt, n1000 + i, id + i); - } -*/ - i = 4; - - n1000[i] = i; - id[i] = id[i]; - -/* os_thread_create(test10_4, n1000 + i, id + i); */ - - i = 5; - -/* test10mt(&i); - - i = 6; - - test10mt(&i); - - trx_purge(); - printf("%lu pages purged\n", purge_sys->n_pages_handled); - - dict_table_print_by_name("TS_TABLE1"); */ - -/* os_thread_create(test_measure_cont, &n3, id + 0); */ - -/* mem_print_info(); */ - - log_make_checkpoint_at(ut_dulint_max); - - n2 = 100; - -/* test2_1(&n2); - - log_flush_up_to(ut_dulint_max, LOG_WAIT_ALL_GROUPS); */ - -/* sync_print(); - - test9A(&n2); - - sync_print(); - - log_print(); - - test9(&n2); - - log_print(); - - sync_print(); */ -/* test6(&n2); */ - -/* test2_2(&n2); */ - -/* test3(&n2); */ - -/* mem_print_info(); */ - - log_archive_stop(); - log_archive_start(); - - ut_a(DB_SUCCESS == log_switch_backup_state_on()); - - printf("Type: kukkuu<enter>\n"); - scanf("%s", buf); - - ut_a(DB_SUCCESS == log_switch_backup_state_off()); - - for (i = 0; i < 2; i++) { - - n1000[i] = 500 + 10 * i; - id[i] = id[i]; -/* - os_thread_create(test2mt, n1000 + i, id + i); - os_thread_create(test2_1mt, n1000 + i, id + i); - os_thread_create(test2_2mt, n1000 + i, id + i); -*/ } - - n2 = 5000; - -/* fsp_print(0); */ - - test2_1(&n2); - - for (i = 0; i < 20; i++) { - log_archive_stop(); - log_archive_start(); - } - -/* test2(&n2); - test2(&n2); */ - -/* buf_print(); - ibuf_print(); - rw_lock_list_print_info(); - mutex_list_print_info(); */ - -/* dict_table_print_by_name("TS_TABLE1"); */ - -/* mem_print_info(); */ -/* - n2 = 100; - - test4_1(); - test4_2(); - - for (i = 0; i < 2; i++) { - n1000[i] = i; - id[i] = id[i]; - os_thread_create(test4mt, n1000 + i, id + i); - } - - n2 = 4; - test4mt(&n2); - - log_archive_stop(); - log_archive_start(); - - test4mt(&n2); -*/ -/* test4_2(); */ -/* - lock_print_info(); -*/ -/* test7(&n2); */ - -/* os_thread_sleep(25000000); */ - -/* ut_a(DB_SUCCESS == log_switch_backup_state_off()); */ - -/* recv_compare_spaces(0, 1, 100); */ - - log_flush_up_to(ut_dulint_max, LOG_WAIT_ALL_GROUPS); - - printf("Type: kukkuu<enter>\n"); - scanf("%s", buf); - - buf_flush_batch(BUF_FLUSH_LIST, ULINT_MAX, ut_dulint_max); - buf_flush_wait_batch_end(BUF_FLUSH_LIST); - -/* log_make_checkpoint_at(ut_dulint_max); */ - -/* dict_table_print_by_name("TS_TABLE1"); */ - -/* buf_print(); */ - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/tsbtrfull.c b/innobase/btr/ts/tsbtrfull.c deleted file mode 100644 index fc8bbb7bffc..00000000000 --- a/innobase/btr/ts/tsbtrfull.c +++ /dev/null @@ -1,4925 +0,0 @@ -/************************************************************************ -Test for the B-tree - -(c) 1994-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "os0proc.h" -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "mem0pool.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "os0thread.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "btr0cur.h" -#include "btr0sea.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "trx0purge.h" -#include "row0ins.h" -#include "row0upd.h" -#include "row0row.h" -#include "row0del.h" -#include "lock0lock.h" -#include "ibuf0ibuf.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 2 /* must be >= 2 */ -#define N_FILES 1 -#define FILE_SIZE 8096 /* must be > 512 */ -#define POOL_SIZE 1524 -#define IBUF_SIZE 200 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - -#define COUNT 1 - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -ulint dummy = 0; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - fil_aio_wait(segment); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to the file -system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[10]; - os_thread_id_t id[10]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - ut_a(ret); - } else { - if (k == 1) { - ut_a(os_file_set_size(files[i], - 8192 * IBUF_SIZE, 0)); - } else { - ut_a(os_file_set_size(files[i], - 8192 * FILE_SIZE, 0)); - } - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - mutex_set_level(&ios_mutex, SYNC_NO_ORDER_CHECK); - - for (i = 0; i < 9; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space headers of spaces 0 and 1. */ - -void -init_spaces(void) -/*=============*/ -{ - mtr_t mtr; - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - fsp_header_init(1, IBUF_SIZE, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -Test for table creation. */ - -ulint -test1( -/*==*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND1", 0, - DICT_UNIQUE | DICT_CLUSTERED, 1); - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -#ifdef notdefined - /*-------------------------------------*/ - /* CREATE YET ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND4", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -#endif -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_5( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.5. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE2", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE2", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_6( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.6. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE3", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE3", "IND1", 0, DICT_CLUSTERED, - 2); - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_7( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.7. CREATE TABLE WITH 12 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE4", 0, 12); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL4", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL5", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL6", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL7", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL8", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL9", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL10", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL11", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL12", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE4", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Test for inserts. */ - -ulint -test2( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - dict_index_t* index; -/* ulint size; */ - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2. MASSIVE INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - /* MASSIVE RANDOM INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 7857641) % 200000; - - dtuple_gen_test_tuple3(row, rnd, - DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 1000 == 0) { - printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); -/* - for (i = 0; i < 10; i++) { - size = ibuf_contract(TRUE); - - printf("%lu bytes will be contracted\n", size); - - os_thread_sleep(1000000); - } -*/ - index = dict_table_get_next_index(dict_table_get_first_index(table)); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - index = dict_table_get_next_index(index); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - btr_search_print_info(); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 7857641) % 200000; - dtuple_gen_search_tuple3(entry, rnd, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); - -/* btr_print_tree(tree, 5); */ - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - btr_validate_tree(tree); - -/* btr_search_print_info(); - dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_1( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ins_node_t* node; - ulint count = 0; - ulint rnd; - dtuple_t* row; -/* dict_tree_t* tree; - dict_index_t* index; - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; */ - - printf("-------------------------------------------------\n"); - printf("TEST 2.1. MASSIVE ASCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 5000 == 0) { - /* ibuf_print(); */ - /* buf_print(); */ - - /* buf_print_io(); */ - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", - i, tm - oldtm); - } - - rnd = rnd + 1; - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined -/* dict_table_print_by_name("TS_TABLE1"); */ - - ibuf_print(); - - index = dict_table_get_first_index(table); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - /* Check inserted entries */ - - btr_search_print_info(); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); -#endif -#ifdef notdefined - /*-------------------------------------*/ - /* ROLLBACK */ - -/* btr_validate_tree(tree); */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_search_print_info(); - -#endif - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - /*-------------------------------------*/ - - count++; -/* btr_validate_tree(tree); */ - - if (count < 1) { - goto loop; - } - - mem_heap_free(heap); - - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_2( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2. MASSIVE DESCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = *((ulint*)arg) + 1; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 200000; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 1000 == 0) { -/* printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); */ - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i + 1, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_validate_tree(tree); -/* dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - btr_validate_tree(tree); - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Multithreaded test for random inserts. */ - -ulint -test2mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2MT. MULTITHREADED RANDOM INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - rnd = 78675; -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - if (i % 100 == 0) { -/* buf_print(); */ -/* ibuf_print(); */ - } - - rnd = (rnd + 7857641) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_1mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.1MT. MULTITHREADED ASCENDING INSERT\n"); - - rnd = 8757677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 98667501; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_2mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2MT. MULTITHREADED DESCENDING INSERT\n"); - - rnd = 87677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 78667; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - mem_print_info(); - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for updates. */ - -ulint -test3( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - byte* ptr; - ulint len; - ulint err; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 3. UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 3; i++) { - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* UPDATE ROWS */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - dtuple_gen_test_tuple3(row, 1, DTUPLE_TEST_RND30, buf); - - entry = dtuple_create(heap, 2); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - dfield_copy(dtuple_get_nth_field(entry, 1), - dtuple_get_nth_field(row, 1)); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), "updated field", 14); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - mtr_start(&mtr); - - ut_a(btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr)); - - ptr = rec_get_nth_field(btr_pcur_get_rec(&pcur), 5, &len); - - ut_a(ut_memcmp(ptr, "updated field", 14) == 0); - - btr_pcur_commit(&pcur); - - dict_table_print_by_name("TS_TABLE1"); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - dfield_set_data(&(ufield->new_val), "31415926", 9); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* ROLLBACK */ -#ifdef notdefined - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ -#endif - dict_table_print_by_name("TS_TABLE1"); - count++; - - if (count < 1) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Init for update test. */ - -ulint -test4_1(void) -/*=========*/ -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - - printf("-------------------------------------------------\n"); - printf("TEST 4.1. UPDATE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/************************************************************************* -Checks that the multithreaded update test has rolled back its updates. */ - -void -test4_2(void) -/*=========*/ -{ - dtuple_t* entry; - mem_heap_t* heap; - mem_heap_t* heap2; - mtr_t mtr; - byte buf[32]; - sess_t* sess; - com_endpoint_t* com_endpoint; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - btr_pcur_t pcur; - rec_t* rec; - - printf("-------------------------------------------------\n"); - printf("TEST 4.2. CHECK UPDATE RESULT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*------------------------------------------*/ - - table = dict_table_get("TS_TABLE1", trx); - - index = dict_table_get_first_index(table); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < 200; i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - rec = btr_pcur_get_rec(&pcur); - - ut_a(0 == cmp_dtuple_rec(entry, rec)); - - heap2 = mem_heap_create(200); - - row = row_build(ROW_COPY_DATA, index, rec, heap2); - - ut_a(30 == dfield_get_len(dtuple_get_nth_field(row, 2))); - ut_a(0 == ut_memcmp( - dfield_get_data(dtuple_get_nth_field(row, 2)), - "12345678901234567890123456789", 30)); - - mem_heap_free(heap2); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -} - -/********************************************************************* -Test for massive updates. */ - -ulint -test4mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 4. MULTITHREADED UPDATES\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 300; i++) { - - rnd += 874681; - tuple_no = (rnd % 40) * 5 + thr_no; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 3000); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(2000000); - - btr_validate_tree(tree); - - ut_a(trx->conc_state != TRX_ACTIVE); - ut_a(UT_LIST_GET_LEN(trx->trx_locks) == 0); - - count++; - - if (count < 2) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for join. */ - -ulint -test6( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ulint count = 0; - dtuple_t* entry; - dict_index_t* index; - dict_tree_t* tree; - btr_pcur_t pcur; - btr_pcur_t pcur2; - mtr_t mtr; - mtr_t mtr2; - ulint rnd; - ulint latch_mode; - - printf("-------------------------------------------------\n"); - printf("TEST 6. MASSIVE EQUIJOIN\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*--------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - /*--------------*/ - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - table = dict_table_get("TS_TABLE1", trx); - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - oldtm = ut_clock(); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IS, thr)); - - rnd = 98651; - - for (i = 0; i < *((ulint*)arg); i++) { - - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - btr_pcur_store_position(&pcur, &mtr); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); - - btr_pcur_commit_specify_mtr(&pcur, &mtr); - - if (i % 1211 == 0) { - dummy++; - } - - rnd = 55321; - - dtuple_gen_search_tuple3(entry, rnd % *((ulint*)arg), buf); - -/* if (i == 0) { */ - latch_mode = BTR_SEARCH_LEAF; -/* } else { - latch_mode = BTR_SEARCH_LEAF | BTR_GUESS_LATCH; - } */ - - mtr_start(&mtr2); - - btr_pcur_open(index, entry, PAGE_CUR_LE, latch_mode, - &pcur2, &mtr2); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur2), - index)); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur2))); - - mtr_commit(&mtr2); - - mtr_start(&mtr); - - btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - tm = ut_clock(); - printf("Wall time for join of %lu rows %lu milliseconds\n", - i, tm - oldtm); - btr_search_index_print_info(index); - /*-------------------------------------*/ - /* COMMIT */ - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); -/* printf("Wall time for commit %lu milliseconds\n", tm - oldtm); */ - - /*-------------------------------------*/ - count++; -/* btr_validate_tree(tree); */ - - if (count < 3) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for lock wait. Requires Test 4.1 first. */ - -ulint -test7( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - trx_t* trx2; - ulint rnd; - dtuple_t* entry; - dtuple_t* row; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 7. LOCK WAIT\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx2 = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - /* UPDATE by trx */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - ut_a(trx_start(trx2, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 2); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - rnd += 874681; - tuple_no = 3; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 1500); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - tm = ut_clock(); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* INSERT by trx2 */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx2; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx2); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx2->sess); - - trx2->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - dtuple_gen_test_tuple3(row, 2, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - /* Insert should be left to wait until trx releases the row lock */ - - que_run_threads(thr); - - tm = ut_clock(); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* COMMIT of trx */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - - /*-------------------------------------*/ - os_thread_sleep(1000000); - - printf( - "trx2 can now continue to do the insert, after trx committed.\n"); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/********************************************************************* -Inserts for TPC-A. */ - -ulint -test8A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 8A. 1000 INSERTS FOR TPC-A\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE2", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 1000; i++) { - dtuple_gen_test_tuple_TPC_A(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < 1000; i++) { - dtuple_gen_search_tuple_TPC_A(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE2"); */ - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for TPC-A transaction. */ - -ulint -test8( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 8. TPC-A %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE2", trx); - - update = upd_create(1, heap); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); - -loop: -/* printf("Round %lu\n", count); */ - - /*-------------------------------------*/ - /* INSERT */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - /*-------------------------------------*/ - /* 3 UPDATES */ - - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - - for (i = 0; i < 3; i++) { - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_A(entry, rnd % 1000, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - -/* ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); */ - -/* btr_pcur_store_position(&pcur, &mtr); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - tm = ut_clock(); - printf("Wall time for TPC-A %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ - - -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Inserts for TPC-C. */ - -ulint -test9A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; -/* dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - dict_index_t* index; - dict_tree_t* tree; -*/ - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 9A. INSERTS FOR TPC-C\n"); - -#define TPC_C_TABLE_SIZE 15000 - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE4", trx); - - row = dtuple_create(heap, 12 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_test_tuple_TPC_C(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_search_tuple_TPC_C(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); -#endif - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE4"); */ - -/* mem_heap_free(heap); */ - return(0); -} - -/********************************************************************* -Test for TPC-C transaction. Test 9A must be run first to populate table. */ - -ulint -test9( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint j; - ulint i; - byte* ptr; - ulint len; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - byte buf2[240]; - rec_t* rec; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 9. TPC-C %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE4", trx); - - update = upd_create(3, heap); - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 2); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); -loop: - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IS, thr)); - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - -/* printf("Round %lu\n", count); */ - -for (j = 0; j < 13; j++) { - - /*-------------------------------------*/ - /* SELECT FROM 'ITEM' */ - - rnd += 876751; - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_S, thr); - ut_a(err == DB_SUCCESS); - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 5; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* UPDATE 'STOCK' */ - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - -/* btr_pcur_store_position(&pcur, &mtr); */ - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 10; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - -/* btr_pcur_commit(&pcur); */ - -/* err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); */ - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); -/* ut_a(err == DB_SUCCESS); */ - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 1); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 2); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - btr_pcur_close(&pcur); - /*-------------------------------------*/ - /* INSERT INTO 'ORDERLINE' */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count * 13 + j, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -} - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - - tm = ut_clock(); - printf("Wall time for TPC-C %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Init for purge test. */ - -ulint -test10_1( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.1. PURGE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i * 100 + thr_no, - DTUPLE_TEST_FIXED30, buf); - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 200); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2_r( -/*=======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 2000); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(2000000); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_3( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.3. PURGE TEST DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - rnd = i; - tuple_no = rnd; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_5( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.5. PURGE TEST UNCOMMITTED DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 50; i++) { - - rnd = i; - tuple_no = rnd % 100; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - return(0); -} - -/********************************************************************* -Multithreaded test for purge. */ - -ulint -test10mt( -/*=====*/ - void* arg) -{ - ulint i; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("Thread %lu starts purge test\n", thr_no); - - for (i = 0; i < 2; i++) { - test10_1(arg); - - sync_print(); - - fsp_validate(0); - - test10_2_r(arg); - sync_print(); - - test10_2(arg); - sync_print(); - - lock_validate(); - - test10_3(arg); - sync_print(); - } - - printf("Thread %lu ends purge test\n", thr_no); - - return(0); -} - -/********************************************************************* -Purge test. */ - -ulint -test10_4( -/*=====*/ - void* arg) -{ - ulint i; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.4. PURGE TEST\n"); - - for (i = 0; i < 30; i++) { - trx_purge(); - - printf("%lu pages purged\n", purge_sys->n_pages_handled); - - os_thread_sleep(5000000); - } - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -This thread is used to test insert buffer merge. */ - -ulint -test_ibuf_merge( -/*============*/ - void* arg) -{ - ulint sum_sizes; - ulint volume; - - ut_ad(arg); - - printf("Starting ibuf merge\n"); - - sum_sizes = 0; - volume = 1; - - while (volume) { - volume = ibuf_contract(FALSE); - - sum_sizes += volume; - } - - printf("Ibuf merged %lu bytes\n", sum_sizes); - - os_thread_sleep(5000000); - - return(0); -} - -/********************************************************************* -This thread is used to measure contention of latches. */ - -ulint -test_measure_cont( -/*==============*/ - void* arg) -{ - ulint i, j; - ulint count; - - ut_ad(arg); - - printf("Starting contention measurement\n"); - - for (i = 0; i < 1000; i++) { - count = 0; - - for (j = 0; j < 100; j++) { - - os_thread_sleep(10000); - - if ((&(buf_pool->mutex))->lock_word) { - - count++; - } - } - - printf("Mutex reserved %lu of %lu peeks\n", count, j); - } - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - os_thread_id_t id[10]; - ulint n1000[10]; - ulint i; - ulint n5000 = 500; - ulint n2; - -/* buf_debug_prints = TRUE; */ - log_do_write = FALSE; - btr_search_use_hash = FALSE; - - srv_boot("initfile"); - os_aio_init(576, 9, 100); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - lock_sys_create(1024); - - create_files(); - - init_spaces(); - - sess_sys_init_at_db_start(); - - trx_sys_create(); - - dict_create(); - -/* os_thread_sleep(500000); */ - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(NULL); - test1_5(NULL); - test1_6(NULL); - test1_7(NULL); - -/* for (i = 0; i < 2; i++) { - - n1000[i] = i; - id[i] = id[i]; - - os_thread_create(test10mt, n1000 + i, id + i); - } -*/ - i = 4; - - n1000[i] = i; - id[i] = id[i]; - -/* os_thread_create(test10_4, n1000 + i, id + i); */ - - i = 5; - -/* test10mt(&i); - - i = 6; - - test10mt(&i); - - trx_purge(); - printf("%lu pages purged\n", purge_sys->n_pages_handled); - - dict_table_print_by_name("TS_TABLE1"); */ - -/* os_thread_create(test_measure_cont, &n3, id + 0); */ - -/* mem_print_info(); */ - -/* dict_table_print_by_name("TS_TABLE1"); */ - - n2 = 2000; - -/* test2_1(&n2); */ - - sync_print(); - - test9A(&n2); - - sync_print(); - - log_print(); - - test9(&n2); - - log_print(); - - sync_print(); -/* test6(&n2); */ - -/* test2(&n2); */ - -/* test2_2(&n2); */ - -/* mem_print_info(); */ - - for (i = 0; i < 2; i++) { - - n1000[i] = 1000 + 10 * i; - id[i] = id[i]; - -/* os_thread_create(test2mt, n1000 + i, id + i); - os_thread_create(test2_1mt, n1000 + i, id + i); - os_thread_create(test2_2mt, n1000 + i, id + i); */ - } - - n2 = 2000; - -/* test2mt(&n2); */ - -/* buf_print(); - ibuf_print(); - rw_lock_list_print_info(); - mutex_list_print_info(); - - dict_table_print_by_name("TS_TABLE1"); */ - -/* mem_print_info(); */ - - n2 = 1000; - -/* test4_1(); - test4_2(); - - for (i = 0; i < 2; i++) { - n1000[i] = i; - id[i] = id[i]; - os_thread_create(test4mt, n1000 + i, id + i); - } - - n2 = 4; - test4mt(&n2); - test4mt(&n2); - test4_2(); - lock_print_info(); */ - -/* test7(&n2); */ - -/* os_thread_sleep(25000000); */ - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/tsbtrins.c b/innobase/btr/ts/tsbtrins.c deleted file mode 100644 index 85eedd292b1..00000000000 --- a/innobase/btr/ts/tsbtrins.c +++ /dev/null @@ -1,802 +0,0 @@ -/************************************************************************ -Test for the B-tree - -(c) 1994-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "os0proc.h" -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "mem0pool.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "os0thread.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "btr0cur.h" -#include "btr0sea.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "trx0purge.h" -#include "row0ins.h" -#include "row0upd.h" -#include "row0row.h" -#include "row0del.h" -#include "lock0lock.h" -#include "ibuf0ibuf.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -#define N_SPACES 2 /* must be >= 2 */ -#define N_FILES 1 -#define FILE_SIZE 8096 /* must be > 512 */ -#define POOL_SIZE 1024 -#define IBUF_SIZE 200 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - -#define COUNT 1 - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -ulint dummy = 0; - -byte test_buf[8000]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to the file -system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[10]; - os_thread_id_t id[10]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - ut_a(ret); - } else { - if (k == 1) { - ut_a(os_file_set_size(files[i], - 8192 * IBUF_SIZE, 0)); - } else { - ut_a(os_file_set_size(files[i], - 8192 * FILE_SIZE, 0)); - } - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - mutex_set_level(&ios_mutex, SYNC_NO_ORDER_CHECK); - - for (i = 0; i < 9; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space headers of spaces 0 and 1. */ - -void -init_spaces(void) -/*=============*/ -{ - mtr_t mtr; - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - fsp_header_init(1, IBUF_SIZE, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -Test for table creation. */ - -ulint -test1( -/*==*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND1", 0, - DICT_UNIQUE | DICT_CLUSTERED, 1); - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -#ifdef notdefined - /*-------------------------------------*/ - /* CREATE YET ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND4", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -#endif -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_1( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ins_node_t* node; - ulint count = 0; - ulint rnd; - dtuple_t* row; - dict_index_t* index; -/* dict_tree_t* tree; - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; */ - - printf("-------------------------------------------------\n"); - printf("TEST 2.1. MASSIVE ASCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - log_print(); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 5000 == 0) { - /* ibuf_print(); */ - /* buf_print(); */ - - /* buf_print_io(); */ - /* - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", - i, tm - oldtm); */ - } - - rnd = rnd + 1; - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - log_print(); - -/* dict_table_print_by_name("TS_TABLE1"); */ - -/* ibuf_print(); */ - - index = index; - - index = dict_table_get_first_index(table); - - if (zero) { - btr_search_index_print_info(index); - } - - btr_validate_tree(dict_index_get_tree(index)); - -#ifdef notdefined - index = dict_table_get_next_index(index); - - if (zero) { - btr_search_index_print_info(index); - } - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - -/* btr_search_index_print_info(index); */ - - btr_validate_tree(dict_index_get_tree(index)); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - /* Check inserted entries */ - - btr_search_print_info(); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); -#endif - /*-------------------------------------*/ - /* ROLLBACK */ - -#ifdef notdefined -/* btr_validate_tree(tree); */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_search_print_info(); -#endif - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - /*-------------------------------------*/ - - count++; -/* btr_validate_tree(tree); */ - - if (count < 1) { - goto loop; - } - - mem_heap_free(heap); - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - os_thread_id_t id[10]; - ulint n1000[10]; - ulint i; - ulint n5000 = 500; - ulint n2; - -/* buf_debug_prints = TRUE; */ - log_do_write = TRUE; - - srv_boot("initfile"); - os_aio_init(576, 9, 100); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - lock_sys_create(1024); - - create_files(); - - init_spaces(); - - sess_sys_init_at_db_start(); - - trx_sys_create(); - - dict_create(); - -/* os_thread_sleep(500000); */ - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(NULL); - -/* for (i = 0; i < 2; i++) { - - n1000[i] = i; - id[i] = id[i]; - - os_thread_create(test10mt, n1000 + i, id + i); - } -*/ - i = 4; - - n1000[i] = i; - id[i] = id[i]; - -/* os_thread_create(test10_4, n1000 + i, id + i); */ - - i = 5; - -/* test10mt(&i); - - i = 6; - - test10mt(&i); - - trx_purge(); - printf("%lu pages purged\n", purge_sys->n_pages_handled); - - dict_table_print_by_name("TS_TABLE1"); */ - -/* os_thread_create(test_measure_cont, &n3, id + 0); */ - -/* mem_print_info(); */ - -/* dict_table_print_by_name("TS_TABLE1"); */ - - log_flush_up_to(ut_dulint_zero); - - os_thread_sleep(500000); - - n2 = 10000; - - test2_1(&n2); - -/* test9A(&n2); - test9(&n2); */ - -/* test6(&n2); */ - -/* test2(&n2); */ - -/* test2_2(&n2); */ - -/* mem_print_info(); */ - - for (i = 0; i < 2; i++) { - - n1000[i] = 1000 + 10 * i; - id[i] = id[i]; - -/* os_thread_create(test2mt, n1000 + i, id + i); - os_thread_create(test2_1mt, n1000 + i, id + i); - os_thread_create(test2_2mt, n1000 + i, id + i); */ - } - - n2 = 2000; - -/* test2mt(&n2); */ - -/* buf_print(); - ibuf_print(); - rw_lock_list_print_info(); - mutex_list_print_info(); - - dict_table_print_by_name("TS_TABLE1"); */ - -/* mem_print_info(); */ - - n2 = 1000; - -/* test4_1(); - test4_2(); - - for (i = 0; i < 2; i++) { - n1000[i] = i; - id[i] = id[i]; - os_thread_create(test4mt, n1000 + i, id + i); - } - - n2 = 4; - test4mt(&n2); - test4mt(&n2); - test4_2(); - lock_print_info(); */ - -/* test7(&n2); */ - -/* os_thread_sleep(25000000); */ - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/tscli.c b/innobase/btr/ts/tscli.c deleted file mode 100644 index 6c42a83cdbe..00000000000 --- a/innobase/btr/ts/tscli.c +++ /dev/null @@ -1,3380 +0,0 @@ -/************************************************************************ -Tests for the client, TPC-C, and TPC-D Query 5 - -(c) 1996-1998 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "univ.i" -#include "ib_odbc.h" -#include "mem0mem.h" -#include "sync0sync.h" -#include "os0thread.h" -#include "os0proc.h" -#include "os0sync.h" -#include "srv0srv.h" - -ulint n_exited = 0; - -/* Disk wait simulation array */ -typedef struct srv_sim_disk_struct srv_sim_disk_t; -struct srv_sim_disk_struct{ - os_event_t event; /* OS event to wait */ - bool event_set;/* TRUE if the event is in the set state */ - bool empty; /* TRUE if this cell not reserved */ -}; - -#define SRV_N_SIM_DISK_ARRAY 150 - -srv_sim_disk_t srv_sim_disk[SRV_N_SIM_DISK_ARRAY]; - -/* Random counter used in disk wait simulation */ -ulint srv_disk_rnd = 982364761; -ulint srv_disk_n_active_threads = 0; - -char cli_srv_endpoint_name[100]; -char cli_user_name[100]; - -ulint n_warehouses = ULINT_MAX; -ulint n_customers_d = ULINT_MAX; -bool is_tpc_d = FALSE; -ulint n_rounds = ULINT_MAX; -ulint n_users = ULINT_MAX; -ulint startdate = 0; -ulint enddate = 0; -bool own_warehouse = FALSE; - -ulint mem_pool_size = ULINT_MAX; - -/********************************************************************* -Test for TPC-C. */ - -ulint -test_init( -/*======*/ - void* arg) -{ - HENV env; - HDBC conn; - RETCODE ret; - HSTMT stat; - HSTMT create_query; - HSTMT populate_query; - char* str; - char* str1; - char* str2; - char* str3; - char* str4; - char* str5; - char* str6; - char* create_str; - char* populate_str; - char* commit_str; - char* new_order_str; - char* payment_str; - char* order_status_str; - char* delivery_str; - char* stock_level_str; - char* consistency_str; - char* query_5_str; - char* print_str; - char* lock_wait_str; - char* join_test_str; - char* test_errors_str; - char* test_group_commit_str; - char* test_single_row_select_str; - char* rollback_str; - char* ibuf_test_str; - SDWORD n_warehouses_buf; - SDWORD n_warehouses_len; - SDWORD n_customers_d_buf; - SDWORD n_customers_d_len; - - UT_NOT_USED(arg); - - /*------------------------------------------------------*/ - - str1 = - -" PROCEDURE CREATE_TABLES () IS" -" BEGIN" -" CREATE TABLE WAREHOUSE (W_ID CHAR, W_NAME CHAR," -" W_STREET_1 CHAR, W_STREET_2 CHAR," -" W_CITY CHAR," -" W_STATE CHAR, W_ZIP CHAR," -" W_TAX INT," -" W_YTD_HIGH INT," -" W_YTD INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX W_IND ON WAREHOUSE (W_ID);" -"" -" CREATE TABLE DISTRICT (D_ID CHAR, D_W_ID CHAR," -" D_NAME CHAR," -" D_STREET_1 CHAR, D_STREET_2 CHAR," -" D_CITY CHAR," -" D_STATE CHAR, D_ZIP CHAR," -" D_TAX INT," -" D_YTD_HIGH INT," -" D_YTD INT," -" D_NEXT_O_ID INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX D_IND ON DISTRICT (D_W_ID, D_ID);" -"" -" CREATE TABLE CUSTOMER (C_ID CHAR, C_D_ID CHAR, C_W_ID CHAR," -" C_FIRST CHAR, C_MIDDLE CHAR," -" C_LAST CHAR," -" C_STREET_1 CHAR, C_STREET_2 CHAR," -" C_CITY CHAR," -" C_STATE CHAR, C_ZIP CHAR," -" C_PHONE CHAR," -" C_SINCE_TIME INT," -" C_SINCE INT," -" C_CREDIT CHAR," -" C_CREDIT_LIM_HIGH INT," -" C_CREDIT_LIM INT," -" C_DISCOUNT INT," -" C_BALANCE_HIGH INT," -" C_BALANCE INT," -" C_YTD_PAYMENT_HIGH INT," -" C_YTD_PAYMENT INT," -" C_PAYMENT_CNT INT," -" C_DELIVERY_CNT INT," -" C_DATA CHAR) /*DOES_NOT_FIT_IN_MEMORY*/;" -"" -" CREATE UNIQUE CLUSTERED INDEX C_IND ON CUSTOMER (C_W_ID, C_D_ID," -" C_ID);" -"" -" CREATE INDEX C_LAST_IND ON CUSTOMER (C_W_ID, C_D_ID, C_LAST," -" C_FIRST);" -"" -" CREATE TABLE HISTORY (H_C_ID CHAR, H_C_D_ID CHAR, H_C_W_ID CHAR," -" H_D_ID CHAR, H_W_ID CHAR," -" H_DATE INT," -" H_AMOUNT INT," -" H_DATA CHAR);" -"" -" CREATE CLUSTERED INDEX H_IND ON HISTORY (H_W_ID);" -"" -" CREATE TABLE NEW_ORDER (NO_O_ID INT," -" NO_D_ID CHAR," -" NO_W_ID CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX NO_IND ON NEW_ORDER (NO_W_ID, NO_D_ID," -" NO_O_ID);" - ; - - str2 = - -" CREATE TABLE ORDERS (O_ID INT, O_D_ID CHAR, O_W_ID CHAR," -" O_C_ID CHAR," -" O_ENTRY_D INT," -" O_CARRIER_ID INT," -" O_OL_CNT INT," -" O_ALL_LOCAL CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX O_IND ON ORDERS (O_W_ID, O_D_ID," -" O_ID);" -" CREATE INDEX O_C_IND ON ORDERS (O_W_ID, O_D_ID, O_C_ID);" -"" -" CREATE TABLE ORDER_LINE (OL_O_ID INT, OL_D_ID CHAR, OL_W_ID CHAR," -" OL_NUMBER CHAR," -" OL_I_ID CHAR," -" OL_SUPPLY_W_ID CHAR," -" OL_DELIVERY_D INT," -" OL_QUANTITY INT," -" OL_AMOUNT INT," -" OL_DIST_INFO CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX OL_IND ON ORDER_LINE" -" (OL_W_ID, OL_D_ID, OL_O_ID, OL_NUMBER);" -"" -" CREATE TABLE ITEM (I_ID CHAR, I_IM_ID CHAR, I_NAME CHAR," -" I_PRICE INT," -" I_DATA CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX I_IND ON ITEM (I_ID);" -"" -" CREATE TABLE STOCK (S_I_ID CHAR," -" S_W_ID CHAR," -" S_QUANTITY INT," -" S_DIST_01 CHAR," -" S_DIST_02 CHAR," -" S_DIST_03 CHAR," -" S_DIST_04 CHAR," -" S_DIST_05 CHAR," -" S_DIST_06 CHAR," -" S_DIST_07 CHAR," -" S_DIST_08 CHAR," -" S_DIST_09 CHAR," -" S_DIST_10 CHAR," -" S_YTD INT," -" S_ORDER_CNT INT," -" S_REMOTE_CNT INT," -" S_DATA CHAR) /*DOES_NOT_FIT_IN_MEMORY*/;" -"" -" CREATE UNIQUE CLUSTERED INDEX S_IND ON STOCK (S_W_ID, S_I_ID);" -"" -"" -" CREATE TABLE REGION (R_REGIONKEY INT, R_NAME CHAR, R_COMMENT CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX R_IND ON REGION (R_REGIONKEY);" -"" -" CREATE TABLE NATION (N_NATIONKEY INT, N_NAME CHAR, N_REGIONKEY INT," -" N_COMMENT CHAR);" -" CREATE UNIQUE CLUSTERED INDEX N_IND ON NATION (N_NATIONKEY);" -"" -" CREATE TABLE NATION_2 (N2_NATIONKEY INT, N2_NAME CHAR," -" N2_REGIONKEY INT, N2_COMMENT CHAR);" -" CREATE UNIQUE CLUSTERED INDEX N2_IND ON NATION_2 (N2_NAME);" -"" -" CREATE TABLE SUPPLIER (S_SUPPKEY INT, S_NAME CHAR, S_ADDRESS CHAR," -" S_NATIONKEY INT, S_PHONE CHAR," -" S_ACCTBAL INT, S_COMMENT CHAR);" -" CREATE UNIQUE CLUSTERED INDEX SU_IND ON SUPPLIER (S_SUPPKEY);" -"" -" CREATE TABLE CUSTOMER_D (C_CUSTKEY INT, C_NAME CHAR, C_ADDRESS CHAR," -" C_NATIONKEY INT, C_PHONE CHAR," -" C_ACCTBAL INT, C_MKTSEGMENT CHAR," -" C_COMMENT CHAR);" -" CREATE UNIQUE CLUSTERED INDEX CU_IND ON CUSTOMER_D (C_CUSTKEY);" -"" -" CREATE TABLE ORDERS_D (O_ORDERKEY INT, O_CUSTKEY INT," -" O_ORDERSTATUS CHAR, O_TOTALPRICE INT," -" O_ORDERDATE INT," -" O_ORDERPRIORITY CHAR," -" O_CLERK CHAR, O_SHIPPRIORITY INT," -" O_COMMENT CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX OR_IND ON ORDERS_D (O_ORDERKEY);" -"" -" CREATE INDEX OR_D_IND ON ORDERS_D (O_ORDERDATE, O_ORDERKEY," -" O_CUSTKEY);" -"" -" CREATE TABLE LINEITEM (L_ORDERKEY INT, L_PARTKEY INT, L_SUPPKEY INT," -" L_LINENUMBER INT, L_QUANTITY INT," -" L_EXTENDEDPRICE INT," -" L_DISCOUNT INT, L_TAX INT," -" L_RETURNFLAG CHAR," -" L_LINESTATUS CHAR," -" L_SHIPDATE INT, L_COMMITDATE INT," -" L_RECEIPTDATE INT," -" L_SHIPINSTRUCT CHAR," -" L_SHIPMODE CHAR, L_COMMENT CHAR);" -"" -" CREATE UNIQUE CLUSTERED INDEX L_IND ON LINEITEM (L_ORDERKEY," -" L_LINENUMBER);" -"" -" CREATE TABLE ACCOUNTA (A_NUM INT, A_BAL INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX ACCOUNTA_IND ON ACCOUNTA (A_NUM);" -"" -" CREATE TABLE TELLERA (T_NUM INT, T_BAL INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX TELLERA_IND ON TELLERA (T_NUM);" -"" -" CREATE TABLE BRANCHA (B_NUM INT, B_BAL INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX BRANCHA_IND ON BRANCHA (B_NUM);" -"" -" CREATE TABLE HISTORYA (H_NUM INT, H_TEXT CHAR);" -"" -" CREATE CLUSTERED INDEX HISTORYA_IND ON HISTORYA (H_NUM);" -"" -" CREATE TABLE JTEST1 (JT1_A INT, JT1_B INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX JT_IND1 ON JTEST1 (JT1_A);" -"" -" CREATE TABLE JTEST2 (JT2_A INT, JT2_B INT);" -"" -" CREATE UNIQUE CLUSTERED INDEX JT_IND2 ON JTEST2 (JT2_A);" -"" -" CREATE TABLE IBUF_TEST (IB_A INT, IB_B CHAR) DOES_NOT_FIT_IN_MEMORY;" -"" -" CREATE UNIQUE CLUSTERED INDEX IBUF_IND ON IBUF_TEST (IB_A);" -" END;" - ; - - create_str = ut_str_catenate(str1, str2); - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE POPULATE_TABLES (n_warehouses IN INT, n_customers_d" -" IN INT) IS" -"" -" i INT;" -" j INT;" -" k INT;" -" t INT;" -" string CHAR;" -" rnd1 INT;" -" rnd2 INT;" -" rnd INT;" -" n_items INT;" -" n_districts INT;" -" n_customers INT;" -"" -" BEGIN" -"" -"/**********************************************************/" -" PRINTF('Starting Mikko-test');" -"" -" FOR i IN 1 .. 5 LOOP" -" INSERT INTO IBUF_TEST VALUES (i, 'Mikko');" -" END LOOP;" -"" -" /* PRINTF('Printing rows from Mikko-test:');" -"" -" ROW_PRINTF SELECT * FROM IBUF_TEST; */" -"" -" SELECT SUM(IB_A) INTO t FROM IBUF_TEST;" -"" -" PRINTF('Sum of 1 to ', i, ' is ', t);" -" ASSERT(t = (i * (i + 1)) / 2);" -"" -" ROLLBACK WORK;" -"" -" PRINTF('Printing rows from Mikko-test after rollback:');" -"" -" ROW_PRINTF SELECT * FROM IBUF_TEST;" -"" -"/**********************************************************/" -" FOR i IN 0 .. 100 LOOP" -" INSERT INTO ACCOUNTA VALUES (i, i);" -" INSERT INTO TELLERA VALUES (i, i);" -" INSERT INTO BRANCHA VALUES (i, i);" -" INSERT INTO HISTORYA VALUES (i, '12345678901234567890');" -" END LOOP;" -"" -" COMMIT WORK;" -"/**********************************************************/" -"/* PRINTF('Populating ibuf test tables');" -" FOR i IN 1 .. 1000 LOOP" -" INSERT INTO IBUF_TEST VALUES (i, RND_STR(RND(1, 2000)));" -" END LOOP;" -" PRINTF('Ibuf test tables populated');" -" COMMIT WORK; */" -"" -" n_items := 200;" -" n_districts := 10;" -" n_customers := 20;" -"" -" PRINTF('Starting to populate ITEMs');" -"" -" FOR i IN 1 .. n_items LOOP" -" rnd1 := RND(26, 50);" -" string := RND_STR(rnd1);" -"" -" IF (RND(0, 99) < 10) THEN" -" rnd2 := RND(0, rnd1 - 8);" -" REPLSTR(string, 'ORIGINAL', rnd2, 8);" -" END IF;" -"" -" INSERT INTO ITEM VALUES (TO_BINARY(i, 3)," -" TO_BINARY(RND(1, 10000), 3)," -" RND_STR(RND(14, 24))," -" RND(100, 10000)," -" string);" -" END LOOP;" -" COMMIT WORK;" -"" -" FOR i IN 1 .. n_warehouses LOOP" -" COMMIT WORK;" -" PRINTF('Starting to populate warehouse number ', i);" -" INSERT INTO WAREHOUSE VALUES (TO_BINARY(i, 2)," -" RND_STR(RND(6, 10))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(2)," -" CONCAT(SUBSTR(TO_CHAR(RND(0, 9999))," -" 6, 4)," -" '11111')," -" RND(0, 2000)," -" 0," -" 0);" -" FOR j IN 1 .. n_items LOOP" -"" -" rnd1 := RND(26, 50);" -" string := RND_STR(rnd1);" -"" -" IF (RND(0, 99) < 10) THEN" -" rnd2 := RND(0, rnd1 - 8);" -" REPLSTR(string, 'ORIGINAL', rnd2, 8);" -" END IF; " -"" -" INSERT INTO STOCK VALUES (TO_BINARY(j, 3)," -" TO_BINARY(i, 2)," -" 91," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" RND_STR(24)," -" 0, 0, 0," -" string);" -" END LOOP;" - ; - - str2 = -" FOR j IN 1 .. n_districts LOOP" -"" -" /* PRINTF('Starting to populate district number ', j); */" -" INSERT INTO DISTRICT VALUES (TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" RND_STR(RND(6, 10))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(2)," -" CONCAT(SUBSTR(" -" TO_CHAR(RND(0, 9999))," -" 6, 4)," -" '11111')," -" RND(0, 2000)," -" 0," -" 0," -" 3001);" -"" -" FOR k IN 1 .. n_customers LOOP" -"" -" string := 'GC';" -"" -" IF (RND(0, 99) < 10) THEN" -" string := 'BC';" -" END IF;" -" " -" INSERT INTO CUSTOMER VALUES (" -" TO_BINARY(k, 3)," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" RND_STR(RND(8, 16))," -" 'OE'," -" CONCAT('NAME'," -" TO_CHAR(k / 3))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(RND(10, 20))," -" RND_STR(2)," -" CONCAT(SUBSTR(" -" TO_CHAR(RND(0, 9999))," -" 6, 4)," -" '11111')," -" RND_STR(16)," -" SYSDATE(), 0," -" string," -" 0, 5000000," -" RND(0, 5000)," -" 0, 0, 0, 0, 0, 0," -" RND_STR(RND(300, 500)));" - ; - - str3 = -" INSERT INTO HISTORY VALUES (" -" TO_BINARY(k, 3)," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" SYSDATE()," -" 1000," -" RND_STR(RND(12, 24)));" -"" -" rnd1 := RND(5, 15);" -"" -" INSERT INTO ORDERS VALUES (" -" k," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" TO_BINARY(k, 3)," -" SYSDATE()," -" RND(1, 10)," -" rnd1," -" '1');" -"" -" FOR t IN 1 .. rnd1 LOOP" -" INSERT INTO ORDER_LINE VALUES (" -" k," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2)," -" TO_BINARY(t, 1)," -" TO_BINARY(" -" RND(1, n_items)," -" 3)," -" TO_BINARY(i, 2)," -" NULL," -" 91," -" RND(0, 9999)," -" RND_STR(24));" -" END LOOP;" -" END LOOP;" -" " -" FOR k IN 1 /* + (2 * n_customers) / 3 */" -" .. n_customers LOOP" -" " -" INSERT INTO NEW_ORDER VALUES (" -" k," -" TO_BINARY(j + 47, 1)," -" TO_BINARY(i, 2));" -" END LOOP;" -" END LOOP;" -" END LOOP;" -"" -" COMMIT WORK;" -"" -" PRINTF('Populating TPC-D tables');" -"" -" FOR i IN 0 .. 4 LOOP" -" /* We set the last columns to a long character string, to" -" reduce latch contention on region and nation database pages." -" A similar effect could be achieved by setting the page" -" fillfactor in these tables low. */" -"" -" INSERT INTO REGION VALUES (i, CONCAT('Region', TO_CHAR(i)," -" ' ')," -" RND_STR(1500 + RND(1, 152)));" -" FOR j IN i * 5 .. i * 5 + 4 LOOP" -" INSERT INTO NATION VALUES (j," -" CONCAT('Nation', TO_CHAR(j)," -" ' ')," -" i, RND_STR(1500 + RND(1, 152)));" -" INSERT INTO NATION_2 VALUES (j," -" CONCAT('Nation', TO_CHAR(j)," -" ' ')," -" i, RND_STR(1500 + RND(1, 152)));" -" END LOOP;" -" END LOOP;" -"" -" COMMIT WORK;" -"" -" FOR i IN 0 .. n_customers_d / 15 LOOP" -" INSERT INTO SUPPLIER VALUES (i," -" CONCAT('Supplier', TO_CHAR(i))," -" RND_STR(RND(20, 30))," -" RND(0, 24)," -" RND_STR(15)," -" RND(1, 1000)," -" RND_STR(RND(40, 80)));" -" END LOOP;" -"" -" COMMIT WORK;" -"" -" FOR i IN 0 .. n_customers_d - 1 LOOP" -" IF ((i / 100) * 100 = i) THEN" -" COMMIT WORK;" -" PRINTF('Populating customer ', i);" -" END IF;" -"" -" INSERT INTO CUSTOMER_D VALUES (i," -" CONCAT('Customer', TO_CHAR(i))," -" RND_STR(RND(20, 30))," -" RND(0, 24)," -" RND_STR(15)," -" RND(1, 1000)," -" RND_STR(10)," -" RND_STR(RND(50, 100)));" -"" -" FOR j IN i * 10 .. i * 10 + 9 LOOP" -"" -" rnd := (j * 2400) / (10 * n_customers_d);" -"" -" INSERT INTO ORDERS_D VALUES (j," -" 3 * RND(0, (n_customers_d / 3) - 1)" -" + RND(1, 2)," -" 'F', 1000," -" rnd," -" RND_STR(10)," -" CONCAT('Clerk', TO_CHAR(RND(0, 1000)))," -" 0, RND_STR(RND(3, 7)));" -"" -" FOR k IN 0 .. RND(0, 6) LOOP" -" INSERT INTO LINEITEM VALUES (j," -" RND(1, 1000)," -" RND(0, n_customers_d / 15)," -" k," -" RND(1, 50)," -" 100," -" 5," -" RND(0, 8)," -" 'N'," -" 'F'," -" rnd + RND(1, 100)," -" rnd + RND(1, 100)," -" rnd + RND(1, 100)," -" RND_STR(1)," -" RND_STR(1)," -" RND_STR(RND(1, 3)));" -" END LOOP;" -" END LOOP;" -"" -" END LOOP;" -"" -" COMMIT WORK;" -" PRINTF('TPC-D tables populated');" -"" -" PRINTF('Populating join test tables');" -" FOR i IN 1 .. 1 LOOP" -" INSERT INTO JTEST1 VALUES (i, i);" -" INSERT INTO JTEST2 VALUES (i, i);" -" END LOOP;" -" PRINTF('Join test tables populated');" -"" -" COMMIT WORK;" -" END;" - ; - - str4 = ut_str_catenate(str1, str2); - populate_str = ut_str_catenate(str4, str3); - - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE PRINT_TABLES () IS" -" i INT;" -" BEGIN" -"" -" /* PRINTF('Printing ITEM table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM ITEM;" -"" -" PRINTF('Printing WAREHOUSE table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM WAREHOUSE;" -"" -" PRINTF('Printing STOCK table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM STOCK;" -"" -" PRINTF('Printing DISTRICT table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM DISTRICT;" -"" -" PRINTF('Printing CUSTOMER table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM CUSTOMER;" -"" -" PRINTF('Printing HISTORY table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM HISTORY;" -"" -" PRINTF('Printing ORDERS table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM ORDERS;" -"" -" PRINTF('Printing ORDER_LINE table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM ORDER_LINE" -" WHERE OL_O_ID >= 3000; */" -"" -" PRINTF('Printing NEW_ORDER table:');" -"" -" ROW_PRINTF" -" SELECT *" -" FROM NEW_ORDER;" -"" -" COMMIT WORK;" -" END;" - ; - - print_str = str; - /*-----------------------------------------------------------*/ - commit_str = - -" PROCEDURE COMMIT_TEST () IS" -" " -" BEGIN" -" COMMIT WORK;" -" END;" - ; - - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE NEW_ORDER (c_w_id IN CHAR," -" c_d_id IN CHAR," -" c_id IN CHAR," -" ol_supply_w_ids IN CHAR," -" ol_i_ids IN CHAR," -" ol_quantities IN CHAR," -" c_last OUT CHAR," -" c_credit OUT CHAR," -" c_discount OUT INT," -" w_tax OUT INT," -" d_tax OUT INT," -" o_ol_count OUT INT," -" o_id OUT INT," -" o_entry_d OUT INT," -" total OUT INT," -" i_names OUT CHAR," -" s_quantities OUT CHAR," -" bg OUT CHAR," -" i_prices OUT CHAR," -" ol_amounts OUT CHAR) IS" -"" -" i INT;" -" j INT;" -" o_all_local CHAR;" -" i_price INT;" -" i_name CHAR;" -" i_data CHAR;" -" s_quantity INT;" -" s_data CHAR;" -" s_dist_01 CHAR;" -" s_dist_02 CHAR;" -" s_dist_03 CHAR;" -" s_dist_04 CHAR;" -" s_dist_05 CHAR;" -" s_dist_06 CHAR;" -" s_dist_07 CHAR;" -" s_dist_08 CHAR;" -" s_dist_09 CHAR;" -" s_dist_10 CHAR;" -" ol_i_id CHAR;" -" ol_quantity INT;" -" ol_amount INT;" -" ol_supply_w_id CHAR;" -" ol_dist_info CHAR;" -"" -" DECLARE CURSOR district_cursor IS" -" SELECT D_NEXT_O_ID, D_TAX" -" FROM DISTRICT" -" WHERE D_ID = c_d_id AND D_W_ID = c_w_id" -" FOR UPDATE;" -"" -" DECLARE CURSOR stock_cursor IS" -" SELECT S_QUANTITY, S_DATA," -" S_DIST_01, S_DIST_02, S_DIST_03, S_DIST_04," -" S_DIST_05, S_DIST_06, S_DIST_07, S_DIST_08," -" S_DIST_09, S_DIST_10" -" FROM STOCK" -" WHERE S_W_ID = ol_supply_w_id AND S_I_ID = ol_i_id" -" FOR UPDATE;" - ; - str2 = - -" BEGIN" -" FOR j IN 1 .. 1 LOOP" -"" -" /* PRINTF('Warehouse ', BINARY_TO_NUMBER(c_w_id)); */" -" o_all_local := '1';" -" i_names := '12345678901234567890123456789012345678901234567890" - "12345678901234567890123456789012345678901234567890" - "12345678901234567890123456789012345678901234567890" - "12345678901234567890123456789012345678901234567890" - "12345678901234567890123456789012345678901234567890" - "12345678901234567890123456789012345678901234567890" - "12345678901234567890123456789012345678901234567890" - "1234567890';" -" s_quantities := '12345678901234567890123456789012345678901234567890" - "1234567890';" -" i_prices := '12345678901234567890123456789012345678901234567890" - "1234567890';" -" ol_amounts := '12345678901234567890123456789012345678901234567890" - "1234567890';" -" bg := 'GGGGGGGGGGGGGGG';" -" total := 0;" -"" -" SELECT C_DISCOUNT, C_LAST, C_CREDIT INTO c_discount, c_last, c_credit" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id AND C_ID = c_id;" -"" -" OPEN district_cursor;" -"" -" FETCH district_cursor INTO o_id, d_tax;" -"" -" UPDATE DISTRICT SET D_NEXT_O_ID = o_id + 1" -" WHERE CURRENT OF district_cursor;" -"" -" CLOSE district_cursor;" -"" -"" - ; - str3 = - -" o_ol_count := LENGTH(ol_quantities);" -"" -" /* PRINTF('C-WAREHOUSE id ', BINARY_TO_NUMBER(c_w_id)," -" ' C-district id ', c_d_id," -" ' order id ', o_id, ' linecount ', o_ol_count); */" -"" -" FOR i IN 0 .. (o_ol_count - 1) LOOP" -"" -" ol_i_id := SUBSTR(ol_i_ids, 3 * i, 3);" -" ol_supply_w_id := SUBSTR(ol_supply_w_ids, 2 * i, 2);" -" ol_quantity := BINARY_TO_NUMBER(SUBSTR(ol_quantities, i, 1));" -"" -" /* PRINTF('ol_i_id ', BINARY_TO_NUMBER(ol_i_id)," -" ' ol_supply_w_id ', BINARY_TO_NUMBER(ol_supply_w_id)," -" ' ol_quantity ', ol_quantity); */" -"" -" SELECT I_PRICE, I_NAME, I_DATA INTO i_price, i_name, i_data" -" FROM ITEM" -" WHERE I_ID = ol_i_id" -" CONSISTENT READ;" -"" -" IF (SQL % NOTFOUND) THEN" -" /* PRINTF('Rolling back; item not found: '," -" BINARY_TO_NUMBER(ol_i_id)); */" -" ROLLBACK WORK;" -" o_ol_count := 0;" -"" -" RETURN;" -" END IF;" -"" -" OPEN stock_cursor;" -"" -" FETCH stock_cursor INTO s_quantity, s_data," -" s_dist_01, s_dist_02, s_dist_03," -" s_dist_04, s_dist_05, s_dist_06," -" s_dist_07, s_dist_08, s_dist_09," -" s_dist_10;" -"" -" /* PRINTF('Stock quantity ', s_quantity); */" -"" -" IF (s_quantity >= ol_quantity + 10) THEN" -" s_quantity := s_quantity - ol_quantity;" -" ELSE" -" s_quantity := (s_quantity + 91) - ol_quantity;" -" END IF;" -"" -" UPDATE STOCK SET S_QUANTITY = s_quantity," -" S_YTD = S_YTD + ol_quantity," -" S_ORDER_CNT = S_ORDER_CNT + 1" - " WHERE CURRENT OF stock_cursor;" -"" -" IF (ol_supply_w_id <> c_w_id) THEN" -"" -" o_all_local := '0';" -" PRINTF('Remote order '," -" BINARY_TO_NUMBER(ol_supply_w_id), ' '," -" BINARY_TO_NUMBER(c_w_id));" -"" -" UPDATE STOCK SET S_REMOTE_CNT = S_REMOTE_CNT + 1" -" WHERE CURRENT OF stock_cursor;" -" END IF;" -"" -" CLOSE stock_cursor;" -"" -" IF ((INSTR(i_data, 'ORIGINAL') > 0)" -" OR (INSTR(s_data, 'ORIGINAL') > 0)) THEN" -" REPLSTR(bg, 'B', i, 1);" -" END IF;" -"" -" ol_amount := ol_quantity * i_price;" -"" -" total := total + ol_amount;" - ; - str4 = -" IF (c_d_id = '0') THEN" -" ol_dist_info := s_dist_01;" -" ELSIF (c_d_id = '1') THEN" -" ol_dist_info := s_dist_02;" -" ELSIF (c_d_id = '2') THEN" -" ol_dist_info := s_dist_03;" -" ELSIF (c_d_id = '3') THEN" -" ol_dist_info := s_dist_04;" -" ELSIF (c_d_id = '4') THEN" -" ol_dist_info := s_dist_05;" -" ELSIF (c_d_id = '5') THEN" -" ol_dist_info := s_dist_06;" -" ELSIF (c_d_id = '6') THEN" -" ol_dist_info := s_dist_07;" -" ELSIF (c_d_id = '7') THEN" -" ol_dist_info := s_dist_08;" -" ELSIF (c_d_id = '8') THEN" -" ol_dist_info := s_dist_09;" -" ELSIF (c_d_id = '9') THEN" -" ol_dist_info := s_dist_10;" -" END IF;" -"" -" INSERT INTO ORDER_LINE VALUES (o_id, c_d_id, c_w_id," -" TO_BINARY(i + 1, 1), ol_i_id," -" ol_supply_w_id, NULL, ol_quantity," -" ol_amount, ol_dist_info);" -"" -" REPLSTR(i_names, i_name, i * 24, LENGTH(i_name));" -" REPLSTR(s_quantities, TO_BINARY(s_quantity, 4), i * 4, 4);" -" REPLSTR(i_prices, TO_BINARY(i_price, 4), i * 4, 4);" -" REPLSTR(ol_amounts, TO_BINARY(ol_amount, 4), i * 4, 4);" -"" -" /* PRINTF('i_name ', i_name, ' s_quantity ', s_quantity," -" ' i_price ', i_price, ' ol_amount ', ol_amount); */" -" END LOOP;" -"" -" SELECT W_TAX INTO w_tax" -" FROM WAREHOUSE" -" WHERE W_ID = c_w_id;" -"" -" total := (((total * (10000 + w_tax + d_tax)) / 10000)" -" * (10000 - c_discount)) / 10000;" -"" -" o_entry_d := SYSDATE();" -"" -" INSERT INTO ORDERS VALUES (o_id, c_d_id, c_w_id, c_id, o_entry_d," -" NULL, o_ol_count, o_all_local);" -" INSERT INTO NEW_ORDER VALUES (o_id, c_d_id, c_w_id);" -"" -" /* PRINTF('Inserted order lines:');" -" ROW_PRINTF" -" SELECT * FROM ORDER_LINE WHERE OL_O_ID = o_id AND" -" OL_D_ID = c_d_id" -" AND OL_W_ID = c_w_id; */" -" COMMIT WORK;" -" END LOOP;" -" END;" - ; - - str5 = ut_str_catenate(str1, str2); - str6 = ut_str_catenate(str3, str4); - - new_order_str = ut_str_catenate(str5, str6); - - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE PAYMENT (c_w_id IN CHAR) IS" -"" -" i INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" w_id CHAR;" -" w_street_1 CHAR;" -" w_street_2 CHAR;" -" w_city CHAR;" -" w_state CHAR;" -" w_zip CHAR;" -" w_name CHAR;" -" d_id CHAR;" -" d_street_1 CHAR;" -" d_street_2 CHAR;" -" d_city CHAR;" -" d_state CHAR;" -" d_zip CHAR;" -" d_name CHAR;" -" c_d_id CHAR;" -" c_street_1 CHAR;" -" c_street_2 CHAR;" -" c_city CHAR;" -" c_state CHAR;" -" c_zip CHAR;" -" c_id CHAR;" -" c_last CHAR;" -" c_first CHAR;" -" c_middle CHAR;" -" c_phone CHAR;" -" c_credit CHAR;" -" c_credit_lim INT;" -" c_discount INT;" -" c_balance INT;" -" c_since INT;" -" c_data CHAR;" -" byname INT;" -" namecnt INT;" -" amount INT;" -" h_data CHAR;" -" h_date INT;" -" c_more_data CHAR;" -" more_len INT;" -" data_len INT;" -"" -" DECLARE CURSOR warehouse_cursor IS" -" SELECT W_STREET_1, W_STREET_2, W_CITY, W_STATE, W_ZIP, W_NAME" -" FROM WAREHOUSE" -" WHERE W_ID = w_id" -" FOR UPDATE;" -"" -" DECLARE CURSOR district_cursor IS" -" SELECT D_STREET_1, D_STREET_2, D_CITY, D_STATE, D_ZIP, D_NAME" -" FROM DISTRICT" -" WHERE D_W_ID = w_id AND D_ID = d_id" -" FOR UPDATE;" -"" -" DECLARE CURSOR customer_by_name_cursor IS" -" SELECT C_ID" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last" -" ORDER BY C_FIRST ASC;" -"" -" DECLARE CURSOR customer_cursor IS" -" SELECT C_FIRST, C_MIDDLE, C_LAST, C_STREET_1, C_STREET_2," -" C_CITY, C_STATE, C_ZIP, C_PHONE, C_CREDIT," -" C_CREDIT_LIM, C_DISCOUNT, C_BALANCE," -" C_SINCE" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_ID = c_id" -" FOR UPDATE;" - ; - - str2 = - -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 20;" -"" -" byname := RND(1, 100);" -" amount := RND(1, 1000);" -" h_date := SYSDATE();" -" w_id := c_w_id;" -" d_id := TO_BINARY(47 + RND(1, n_districts), 1);" -" c_d_id := TO_BINARY(47 + RND(1, n_districts), 1);" -"" -" IF (byname <= 60) THEN" -" c_last := CONCAT('NAME', TO_CHAR(RND(1, n_customers) / 3));" -"" -" SELECT COUNT(*) INTO namecnt" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last;" -" /* PRINTF('Payment trx: Customer name ', c_last," -" ' namecount ', namecnt); */" -" OPEN customer_by_name_cursor;" -"" -" FOR i IN 1 .. (namecnt + 1) / 2 LOOP" -" FETCH customer_by_name_cursor INTO c_id;" -" END LOOP;" -" /* ASSERT(NOT (customer_by_name_cursor % NOTFOUND)); */" -" " -" CLOSE customer_by_name_cursor;" -" ELSE" -" c_id := TO_BINARY(RND(1, n_customers), 3);" -" END IF;" - - ; - str3 = -"" -" /* PRINTF('Payment for customer ', BINARY_TO_NUMBER(c_w_id), ' '," -" c_d_id, ' ', BINARY_TO_NUMBER(c_id)); */" -" OPEN customer_cursor;" -"" -" FETCH customer_cursor INTO c_first, c_middle, c_last, c_street_1," -" c_street_2, c_city, c_state, c_zip," -" c_phone, c_credit, c_credit_lim," -" c_discount, c_balance, c_since;" -" c_balance := c_balance - amount;" -"" -" OPEN district_cursor;" -"" -" FETCH district_cursor INTO d_street_1, d_street_2, d_city, d_state," -" d_zip, d_name;" -" UPDATE DISTRICT SET D_YTD = D_YTD + amount" -" WHERE CURRENT OF district_cursor;" -"" -" CLOSE district_cursor;" -"" -" OPEN warehouse_cursor;" -"" -" FETCH warehouse_cursor INTO w_street_1, w_street_2, w_city, w_state," -" w_zip, w_name;" -" UPDATE WAREHOUSE SET W_YTD = W_YTD + amount" -" WHERE CURRENT OF warehouse_cursor;" -"" -" CLOSE warehouse_cursor;" -"" -" h_data := CONCAT(w_name, ' ', d_name);" -" " -" IF (c_credit = 'BC') THEN" -" /* PRINTF('Bad customer pays'); */" -"" -" SELECT C_DATA INTO c_data" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_ID = c_id;" -" c_more_data := CONCAT(" -" ' ', TO_CHAR(BINARY_TO_NUMBER(c_id))," -" ' ', c_d_id," -" ' ', TO_CHAR(BINARY_TO_NUMBER(c_w_id))," -" ' ', d_id," -" ' ', TO_CHAR(BINARY_TO_NUMBER(w_id))," -" TO_CHAR(amount)," -" TO_CHAR(h_date)," -" ' ', h_data);" -"" -" more_len := LENGTH(c_more_data);" -" data_len := LENGTH(c_data);" -" " -" IF (more_len + data_len > 500) THEN" -" data_len := 500 - more_len;" -" END IF;" -" " -" c_data := CONCAT(c_more_data, SUBSTR(c_data, 0, data_len));" -" " -" UPDATE CUSTOMER SET C_BALANCE = c_balance," -" C_PAYMENT_CNT = C_PAYMENT_CNT + 1," -" C_YTD_PAYMENT = C_YTD_PAYMENT + amount," -" C_DATA = c_data" -" WHERE CURRENT OF customer_cursor;" -" ELSE" -" UPDATE CUSTOMER SET C_BALANCE = c_balance," -" C_PAYMENT_CNT = C_PAYMENT_CNT + 1," -" C_YTD_PAYMENT = C_YTD_PAYMENT + amount" -" WHERE CURRENT OF customer_cursor;" -" END IF;" -"" -" CLOSE customer_cursor;" -" " -" INSERT INTO HISTORY VALUES (c_d_id, c_w_id, c_id, d_id, w_id," -" h_date, amount, h_data);" -" COMMIT WORK;" -"" -" END;" - - ; - - str4 = ut_str_catenate(str1, str2); - payment_str = ut_str_catenate(str4, str3); - - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE ORDER_STATUS (c_w_id IN CHAR) IS" -"" -" i INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" d_id CHAR;" -" namecnt INT;" -" c_d_id CHAR;" -" c_id CHAR;" -" c_last CHAR;" -" c_first CHAR;" -" c_middle CHAR;" -" c_balance INT;" -" byname INT;" -" o_id INT;" -" o_carrier_id CHAR;" -" o_entry_d INT;" -" ol_i_id CHAR;" -" ol_supply_w_id CHAR;" -" ol_quantity INT;" -" ol_amount INT;" -" ol_delivery_d INT;" -"" -" DECLARE CURSOR orders_cursor IS" -" SELECT O_ID, O_CARRIER_ID, O_ENTRY_D" -" FROM ORDERS" -" WHERE O_W_ID = c_w_id AND O_D_ID = c_d_id" -" AND O_C_ID = c_id" -" ORDER BY O_ID DESC;" -"" -" DECLARE CURSOR order_line_cursor IS" -" SELECT OL_I_ID, OL_SUPPLY_W_ID, OL_QUANTITY, OL_AMOUNT," -" OL_DELIVERY_D" -" FROM ORDER_LINE" -" WHERE OL_W_ID = c_w_id AND OL_D_ID = c_d_id" -" AND OL_O_ID = o_id;" -" DECLARE CURSOR customer_by_name_cursor IS" -" SELECT C_ID" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last" -" ORDER BY C_FIRST ASC;" -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 20;" -"" -" byname := RND(1, 100);" -"" - ; - - str2 = - -" IF (byname <= 60) THEN" -" d_id := TO_BINARY(47 + RND(1, n_districts), 1); " -"" -" c_d_id := d_id;" -"" -" c_last := CONCAT('NAME', TO_CHAR(RND(1, n_customers) / 3));" -"" -" SELECT COUNT(*) INTO namecnt" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id" -" AND C_LAST = c_last;" -" OPEN customer_by_name_cursor;" -"" -" /* PRINTF('Order status trx: Customer name ', c_last," -" ' namecount ', namecnt); */" -" FOR i IN 1 .. (namecnt + 1) / 2 LOOP" -" FETCH customer_by_name_cursor INTO c_id;" -" END LOOP;" -" /* ASSERT(NOT (customer_by_name_cursor % NOTFOUND)); */" -"" -" CLOSE customer_by_name_cursor;" -" ELSE" -" c_d_id := TO_BINARY(47 + RND(1, n_districts), 1);" -" c_id := TO_BINARY(RND(1, n_customers), 3);" -" END IF;" -"" -" SELECT C_BALANCE, C_FIRST, C_MIDDLE, C_LAST INTO c_balance, c_first," -" c_middle, c_last" -" FROM CUSTOMER" -" WHERE C_W_ID = c_w_id AND C_D_ID = c_d_id AND C_ID = c_id;" -"" -" OPEN orders_cursor;" -"" -" FETCH orders_cursor INTO o_id, o_carrier_id, o_entry_d;" -"" -" IF (orders_cursor % NOTFOUND) THEN" -" PRINTF('Order status trx: customer has no order');" -" CLOSE orders_cursor;" -"" -" COMMIT WORK;" -"" -" RETURN;" -" END IF;" -"" -" CLOSE orders_cursor;" -"" -" OPEN order_line_cursor;" -"" -" FOR i IN 0 .. 15 LOOP" -" FETCH order_line_cursor INTO ol_i_id, ol_supply_w_id," -" ol_quantity, ol_amount," -" ol_delivery_d;" -"" -" IF (order_line_cursor % NOTFOUND) THEN" -" CLOSE order_line_cursor;" -"" -" COMMIT WORK;" -"" -" RETURN;" -" END IF;" -" END LOOP;" -" ASSERT(0 = 1);" -" " -" END;" - ; - - order_status_str = ut_str_catenate(str1, str2); - /*-----------------------------------------------------------*/ - - str1 = - -" PROCEDURE DELIVERY (w_id IN CHAR) IS" -"" -" i INT;" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" d_id CHAR;" -" c_id CHAR;" -" o_id INT;" -" o_carrier_id INT;" -" ol_delivery_d INT;" -" ol_total INT;" -"" -" DECLARE CURSOR new_order_cursor IS" -" SELECT NO_O_ID" -" FROM NEW_ORDER" -" WHERE NO_W_ID = w_id AND NO_D_ID = d_id" -" ORDER BY NO_O_ID ASC;" -"" -" DECLARE CURSOR orders_cursor IS" -" SELECT O_C_ID" -" FROM ORDERS" -" WHERE O_W_ID = w_id AND O_D_ID = d_id" -" AND O_ID = o_id" -" FOR UPDATE;" -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 20;" -"" -" o_carrier_id := RND(1, 10);" -" ol_delivery_d := SYSDATE();" - - ; - - str2 = - -" FOR i IN 1 .. n_districts LOOP" -"" -" d_id := TO_BINARY(47 + i, 1);" -"" -" OPEN new_order_cursor;" -"" -" FETCH new_order_cursor INTO o_id;" -"" -" IF (new_order_cursor % NOTFOUND) THEN" -" /* PRINTF('No order to deliver'); */" -"" -" CLOSE new_order_cursor;" -" ELSE" -" CLOSE new_order_cursor;" -"" -" DELETE FROM NEW_ORDER" -" WHERE NO_W_ID = w_id AND NO_D_ID = d_id" -" AND NO_O_ID = o_id;" -" OPEN orders_cursor;" -"" -" FETCH orders_cursor INTO c_id;" -"" -" UPDATE ORDERS SET O_CARRIER_ID = o_carrier_id" -" WHERE CURRENT OF orders_cursor;" -"" -" CLOSE orders_cursor;" -"" -" UPDATE ORDER_LINE SET OL_DELIVERY_D = ol_delivery_d" -" WHERE OL_W_ID = w_id AND OL_D_ID = d_id" -" AND OL_O_ID = o_id;" -"" -" SELECT SUM(OL_AMOUNT) INTO ol_total" -" FROM ORDER_LINE" -" WHERE OL_W_ID = w_id AND OL_D_ID = d_id" -" AND OL_O_ID = o_id;" -"" -" UPDATE CUSTOMER SET C_BALANCE = C_BALANCE - ol_total" -" WHERE C_W_ID = w_id AND C_D_ID = d_id" -" AND C_ID = c_id;" -" END IF;" -" END LOOP;" -" COMMIT WORK;" -"" -" " -" END;" - ; - - delivery_str = ut_str_catenate(str1, str2); - - /*-----------------------------------------------------------*/ - - str = - -" PROCEDURE STOCK_LEVEL (w_id IN CHAR) IS" -"" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" d_id CHAR;" -" o_id INT;" -" stock_count INT;" -" threshold INT;" -"" -" BEGIN" -"" -" n_items := 200;" -" n_warehouses := 1;" -" n_districts := 10;" -" n_customers := 20;" -"" -" d_id := TO_BINARY(47 + 4, 1);" -"" -" threshold := RND(10, 20);" -"" -" SELECT D_NEXT_O_ID INTO o_id" -" FROM DISTRICT" -" WHERE D_W_ID = w_id AND D_ID = d_id;" -"" -" /* NOTE: COUNT(DISTINCT ...) not implemented yet: if we used a hash" -" table, the DISTINCT operation should take at most 15 % more time */" -"" -" SELECT COUNT(*) INTO stock_count" -" FROM ORDER_LINE, STOCK" -" WHERE OL_W_ID = w_id AND OL_D_ID = d_id" -" AND OL_O_ID >= o_id - 10 AND OL_O_ID < o_id" -" AND S_W_ID = w_id AND S_I_ID = OL_I_ID" -" AND S_QUANTITY < threshold" -" CONSISTENT READ;" -" /* PRINTF(stock_count, ' items under threshold ', threshold); */" -" COMMIT WORK;" -"" -" END;" - ; - - stock_level_str = str; - - /*-----------------------------------------------------------*/ - - str = - -" PROCEDURE TPC_CONSISTENCY () IS" -"" -" n_items INT;" -" n_warehouses INT;" -" n_districts INT;" -" n_customers INT;" -" n_orders INT;" -" n_new_orders INT;" -" n_order_lines INT;" -" n_history INT;" -" sum_order_quant INT;" -" sum_stock_quant INT;" -" n_delivered INT;" -" n INT;" -" n_new_order_lines INT;" -" n_customers_d INT;" -" n_regions INT;" -" n_nations INT;" -" n_suppliers INT;" -" n_orders_d INT;" -" n_lineitems INT;" -"" -" BEGIN" -"" -" PRINTF('TPC-C consistency check begins');" -"" -" SELECT COUNT(*) INTO n_warehouses" -" FROM WAREHOUSE;" -" SELECT COUNT(*) INTO n_items" -" FROM ITEM;" -" SELECT COUNT(*) INTO n_customers" -" FROM CUSTOMER;" -" SELECT COUNT(*) INTO n_districts" -" FROM DISTRICT;" -" SELECT COUNT(*) INTO n_orders" -" FROM ORDERS;" -" SELECT COUNT(*) INTO n_new_orders" -" FROM NEW_ORDER;" -" SELECT COUNT(*) INTO n_order_lines" -" FROM ORDER_LINE;" -" SELECT COUNT(*) INTO n_history" -" FROM HISTORY;" -"" -" PRINTF('N warehouses ', n_warehouses);" -"" -" PRINTF('N items ', n_items, ' : ', n_items / n_warehouses," -" ' per warehouse');" -" PRINTF('N districts ', n_districts, ' : ', n_districts / n_warehouses," -" ' per warehouse');" -" PRINTF('N customers ', n_customers, ' : ', n_customers / n_districts," -" ' per district');" -" PRINTF('N orders ', n_orders, ' : ', n_orders / n_customers," -" ' per customer');" -" PRINTF('N new orders ', n_new_orders, ' : '," -" n_new_orders / n_customers, ' per customer');" -" PRINTF('N order lines ', n_order_lines, ' : '," -" n_order_lines / n_orders, ' per order');" -" PRINTF('N history ', n_history, ' : '," -" n_history / n_customers, ' per customer');" -" SELECT COUNT(*) INTO n_delivered" -" FROM ORDER_LINE" -" WHERE OL_DELIVERY_D < NULL;" -"" -" PRINTF('N delivered order lines ', n_delivered);" -"" -" SELECT COUNT(*) INTO n_new_order_lines" -" FROM NEW_ORDER, ORDER_LINE" -" WHERE NO_O_ID = OL_O_ID AND NO_D_ID = OL_D_ID" -" AND NO_W_ID = OL_W_ID;" -" PRINTF('N new order lines ', n_new_order_lines);" -"" -" SELECT COUNT(*) INTO n" -" FROM NEW_ORDER, ORDER_LINE" -" WHERE NO_O_ID = OL_O_ID AND NO_D_ID = OL_D_ID" -" AND NO_W_ID = OL_W_ID AND OL_DELIVERY_D < NULL;" -" PRINTF('Assertion 1');" -" ASSERT(n = 0);" -"" -" SELECT COUNT(*) INTO n" -" FROM NEW_ORDER, ORDER_LINE" -" WHERE NO_O_ID = OL_O_ID AND NO_D_ID = OL_D_ID" -" AND NO_W_ID = OL_W_ID AND OL_DELIVERY_D = NULL;" -"" -" PRINTF('Assertion 2');" -" ASSERT(n = n_new_order_lines);" -" PRINTF('Assertion 2B');" -" ASSERT(n_delivered + n_new_order_lines = n_order_lines);" -"" -" PRINTF('Assertion 3');" -" /* ASSERT(n_orders <= n_history); */" -" PRINTF('Assertion 4');" -" ASSERT(n_order_lines <= 15 * n_orders);" -" PRINTF('Assertion 5');" -" ASSERT(n_order_lines >= 5 * n_orders);" -" PRINTF('Assertion 6');" -" ASSERT(n_new_orders <= n_orders);" -"" -" SELECT SUM(OL_QUANTITY) INTO sum_order_quant" -" FROM ORDER_LINE;" -" SELECT SUM(S_QUANTITY) INTO sum_stock_quant" -" FROM STOCK;" -" PRINTF('Sum order quant ', sum_order_quant, ' sum stock quant '," -" sum_stock_quant);" -"" -" PRINTF('Assertion 7');" -" ASSERT(((sum_stock_quant + sum_order_quant) / 91) * 91" -" = sum_stock_quant + sum_order_quant);" -" COMMIT WORK;" -" PRINTF('TPC-C consistency check passed');" -"" -" PRINTF('TPC-D consistency check begins');" -"" -" SELECT COUNT(*) INTO n_customers_d" -" FROM CUSTOMER_D" -" CONSISTENT READ;" -" SELECT COUNT(*) INTO n_nations" -" FROM NATION" -" CONSISTENT READ;" -" SELECT COUNT(*) INTO n_regions" -" FROM REGION" -" CONSISTENT READ;" -" SELECT COUNT(*) INTO n_suppliers" -" FROM SUPPLIER" -" CONSISTENT READ;" -" SELECT COUNT(*) INTO n_orders_d" -" FROM ORDERS_D" -" CONSISTENT READ;" -" SELECT COUNT(*) INTO n_lineitems" -" FROM LINEITEM" -" CONSISTENT READ;" -"" -" PRINTF('N customers TPC-D ', n_customers_d);" -"" -" PRINTF('N nations ', n_nations);" -" PRINTF('N regions ', n_regions);" -"" -" PRINTF('N suppliers ', n_suppliers);" -" PRINTF('N orders TPC-D ', n_orders_d);" -"" -" PRINTF('N lineitems ', n_lineitems, ' : '," -" n_lineitems / n_orders_d, ' per order');" -" SELECT COUNT(*) INTO n" -" FROM NATION, NATION_2" -" WHERE N_NAME = N2_NAME" -" CONSISTENT READ;" -"" -" PRINTF('Assertion D1');" -" ASSERT(n = n_nations);" -"" -" SELECT COUNT(*) INTO n" -" FROM NATION, REGION" -" WHERE N_REGIONKEY = R_REGIONKEY" -" CONSISTENT READ;" -"" -" PRINTF('Assertion D2');" -" ASSERT(n = n_nations);" -"" -" SELECT COUNT(*) INTO n" -" FROM ORDERS_D, CUSTOMER_D" -" WHERE O_CUSTKEY = C_CUSTKEY" -" CONSISTENT READ;" -"" -" PRINTF('Assertion D3');" -" ASSERT(n = n_orders_d);" -"" -" SELECT COUNT(*) INTO n" -" FROM LINEITEM, SUPPLIER" -" WHERE L_SUPPKEY = S_SUPPKEY" -" CONSISTENT READ;" -"" -" PRINTF('Assertion D4');" -" ASSERT(n = n_lineitems);" -"" -" SELECT COUNT(*) INTO n" -" FROM ORDERS_D" -" WHERE O_ORDERDATE >= 0" -" AND O_ORDERDATE <= 2500" -" CONSISTENT READ;" -"" -" PRINTF('Assertion D5');" -" ASSERT(n = n_orders_d);" -"" -" COMMIT WORK;" -" PRINTF('TPC-D consistency check passed');" -"" -" END;" - ; - - consistency_str = str; - - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE TPC_D_QUERY_5 (startday IN INT, endday IN INT) IS" -"" -" revenue INT;" -" r_name CHAR;" -"" -" BEGIN" -"" -" r_name := CONCAT('Region', TO_CHAR(3), ' ');" -"" -" /* The last join to NATION_2 corresponds to calculating" -" GROUP BY N_NAME in the original TPC-D query. It should take" -" approximately the same amount of CPU time as GROUP BY. */" -"" -" SELECT SUM((L_EXTENDEDPRICE * (100 - L_DISCOUNT)) / 100)" -" INTO revenue" -" FROM REGION, ORDERS_D, CUSTOMER_D, NATION," -" LINEITEM, SUPPLIER, NATION_2" -" WHERE R_NAME = r_name" -" AND O_ORDERDATE >= startday" -" AND O_ORDERDATE < endday" -" AND O_CUSTKEY = C_CUSTKEY" -" AND C_NATIONKEY = N_NATIONKEY" -" AND N_REGIONKEY = R_REGIONKEY" -" AND O_ORDERKEY = L_ORDERKEY" -" AND L_SUPPKEY = S_SUPPKEY" -" AND S_NATIONKEY = C_NATIONKEY" -" AND N_NAME = N2_NAME" -" CONSISTENT READ;" -"" -" PRINTF('Startdate ', startday, '; enddate ', endday," -" ': revenue ', revenue);" -" COMMIT WORK;" -"" -" END;" - ; - - query_5_str = str; - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE ROLLBACK_QUERY () IS" -"" -" BEGIN" -"" -" ROLLBACK WORK;" -"" -" END;" - ; - - rollback_str = str; - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE TEST_LOCK_WAIT () IS" -"" -" w_id CHAR;" -" BEGIN" -"" -" w_id := TO_BINARY(1, 2);" -" UPDATE WAREHOUSE SET W_YTD = W_YTD + 1 WHERE W_ID = w_id;" -"" -" END;" - ; - - lock_wait_str = str; - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE TEST_IBUF () IS" -"" -" i INT;" -" rnd INT;" -" j INT;" -" found INT;" -"" -" DECLARE CURSOR desc_cursor IS" -" SELECT IB_A" -" FROM IBUF_TEST" -" WHERE IB_A >= rnd AND IB_A < rnd + 50" -" ORDER BY IB_A DESC;" -"" -" BEGIN" -"" -" PRINTF('Ibuf QUERY starts!!!!!!');" -" rnd := RND(1, 1000);" -"" -" FOR i IN 1 .. 50 LOOP" -" INSERT INTO IBUF_TEST VALUES (rnd + i," -" RND_STR(RND(1, 2000)));" -" END LOOP;" -" IF (RND(1, 100) < 30) THEN" -" PRINTF('Ibuf rolling back ---!!!');" -" ROLLBACK WORK;" -" END IF;" -"" -"" -" IF (RND(1, 100) < 101) THEN" -" rnd := RND(1, 1000);" -" DELETE FROM IBUF_TEST WHERE IB_A >= rnd " -" AND IB_A <= rnd + 50;" -" END IF;" -"" -" rnd := RND(1, 1000);" -" SELECT COUNT(*) INTO j" -" FROM IBUF_TEST" -" WHERE IB_A >= rnd AND IB_A < rnd + 50;" -"" -" PRINTF('Count: ', j);" -"" -" rnd := RND(1, 1000);" -" UPDATE IBUF_TEST" -" SET IB_B = RND_STR(RND(1, 2000))" -" WHERE IB_A >= rnd AND IB_A < rnd + 50;" -"" -" OPEN desc_cursor;" -"" -" rnd := RND(1, 1000);" -" found := 1;" -" WHILE (found > 0) LOOP" -"" -" FETCH desc_cursor INTO j;" -"" -" IF (desc_cursor % NOTFOUND) THEN" -" found := 0;" -" END IF;" -" END LOOP;" -"" -" CLOSE desc_cursor;" -"" -" IF (RND(1, 100) < 30) THEN" -" PRINTF('Ibuf rolling back!!!');" -" ROLLBACK WORK;" -" ELSE" -" COMMIT WORK;" -" END IF;" -"" -" PRINTF('Ibuf QUERY ends!!!!!!');" -" END;" - ; - - ibuf_test_str = str; - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE TEST_GROUP_COMMIT (w_id IN CHAR) IS" -"" -" i INT;" -"" -" BEGIN" -"" -" FOR i IN 1 .. 200 LOOP" -" UPDATE WAREHOUSE SET W_YTD = W_YTD + 1 WHERE W_ID = w_id;" -" COMMIT WORK;" -" END LOOP;" -" END;" - ; - - test_group_commit_str = str; - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE TEST_SINGLE_ROW_SELECT (" -" i_id IN CHAR," -" i_name OUT CHAR) IS" -" BEGIN" -" SELECT I_NAME INTO i_name" -" FROM ITEM" -" WHERE I_ID = i_id" -" CONSISTENT READ;" -" END;" - ; - - test_single_row_select_str = str; - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE JOIN_TEST () IS" -"" -" n_rows INT;" -" i INT;" -"" -" BEGIN" -"" -" FOR i IN 0 .. 0 LOOP" -" SELECT COUNT(*) INTO n_rows" -" FROM JTEST1, JTEST2" -" WHERE JT2_A = JT1_B" -" CONSISTENT READ;" -" PRINTF(n_rows);" -"" -" COMMIT WORK;" -" END LOOP;" -"" -" END;" - ; - - join_test_str = str; - - /*-----------------------------------------------------------*/ - str = - -" PROCEDURE TEST_ERRORS (switch IN CHAR) IS" -"" -" count INT;" -" val INT;" -"" -" BEGIN" -"" -" IF (switch = '01') THEN" -" /* Test duplicate key error: run this first */" -" ROW_PRINTF SELECT * FROM JTEST1;" -" PRINTF('To insert first');" -" INSERT INTO JTEST1 VALUES (1, 1);" -" PRINTF('To insert second');" -" INSERT INTO JTEST1 VALUES (2, 2);" -" END IF;" -"" -" IF (switch = '02') THEN" -" /* Test duplicate key error: run this second */" -" ROW_PRINTF SELECT * FROM JTEST1;" -" PRINTF('To insert third');" -" INSERT INTO JTEST1 VALUES (3, 3);" -" ROW_PRINTF SELECT * FROM JTEST1;" -" PRINTF('To insert fourth');" -" INSERT INTO JTEST1 VALUES (1, 1);" -" END IF;" -"" -" IF (switch = '03') THEN" -" /* Test duplicate key error: run this third */" -" ROW_PRINTF SELECT * FROM JTEST1;" -" PRINTF('Testing assert');" -" SELECT COUNT(*) INTO count FROM JTEST1;" -" ASSERT(count = 2);" -" END IF;" -"" -" IF (switch = '04') THEN" -" /* Test duplicate key error: run this fourth */" -" ROW_PRINTF SELECT * FROM JTEST1;" -" PRINTF('Testing update');" -" UPDATE JTEST1 SET JT1_A = 3 WHERE JT1_A = 2;" -" PRINTF('Testing update');" -" UPDATE JTEST1 SET JT1_A = 1 WHERE JT1_A = 3;" -" END IF;" -"" -" IF (switch = '05') THEN" -" /* Test deadlock error: run this fifth in thread 1 */" -" COMMIT WORK;" -" PRINTF('Testing update in thread 1');" -" UPDATE JTEST1 SET JT1_B = 3 WHERE JT1_A = 1;" -" END IF;" -"" -" IF (switch = '06') THEN" -" /* Test deadlock error: run this sixth in thread 2 */" -" PRINTF('Testing update in thread 2');" -" UPDATE JTEST1 SET JT1_B = 10 WHERE JT1_A = 2;" -" PRINTF('Testing update in thread 2');" -" UPDATE JTEST1 SET JT1_B = 11 WHERE JT1_A = 1;" -" PRINTF('Update in thread 2 completed');" -" SELECT JT1_B INTO val FROM JTEST1 WHERE JT1_A = 1;" -" ASSERT(val = 11);" -" SELECT JT1_B INTO val FROM JTEST1 WHERE JT1_A = 2;" -" ASSERT(val = 10);" -" COMMIT WORK;" -" END IF;" -"" -" IF (switch = '07') THEN" -" /* Test deadlock error: run this seventh in thread 1 */" -" PRINTF('Testing update in thread 1: deadlock');" -" UPDATE JTEST1 SET JT1_B = 4 WHERE JT1_A = 2;" -" END IF;" -"" -" IF (switch = '08') THEN" -" /* Test deadlock error: run this eighth in thread 1 */" -" PRINTF('Testing update in thread 1: commit');" -" SELECT JT1_B INTO val FROM JTEST1 WHERE JT1_A = 1;" -" ASSERT(val = 3);" -" COMMIT WORK;" -" END IF;" -"" -" END;" - ; - - test_errors_str = str; - /*-----------------------------------------------------------*/ - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &create_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &populate_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLConnect(conn, (UCHAR*)cli_srv_endpoint_name, - (SWORD)ut_strlen(cli_srv_endpoint_name), - (UCHAR*)"use21", 5, (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - /*-----------------------------------------------------------*/ - ret = SQLPrepare(stat, (UCHAR*)create_str, ut_strlen(create_str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - str = "{CREATE_TABLES()}"; - - ret = SQLPrepare(create_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(create_query); - - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - ret = SQLPrepare(stat, (UCHAR*)populate_str, ut_strlen(populate_str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)lock_wait_str, - ut_strlen(lock_wait_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)commit_str, - ut_strlen(commit_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)print_str, - ut_strlen(print_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)new_order_str, - ut_strlen(new_order_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)payment_str, - ut_strlen(payment_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)order_status_str, - ut_strlen(order_status_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)delivery_str, - ut_strlen(delivery_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)stock_level_str, - ut_strlen(stock_level_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)query_5_str, - ut_strlen(query_5_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)consistency_str, - ut_strlen(consistency_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)rollback_str, ut_strlen(rollback_str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)join_test_str, - ut_strlen(join_test_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)test_errors_str, - ut_strlen(test_errors_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)test_single_row_select_str, - ut_strlen(test_single_row_select_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)test_group_commit_str, - ut_strlen(test_group_commit_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLPrepare(stat, (UCHAR*)ibuf_test_str, - ut_strlen(ibuf_test_str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(stat); - - ut_a(ret == SQL_SUCCESS); - - str = "{POPULATE_TABLES(?, ?)}"; - - ret = SQLPrepare(populate_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(populate_query, 1, SQL_PARAM_INPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&n_warehouses_buf, - 4, &n_warehouses_len); - ut_a(ret == SQL_SUCCESS); - - n_warehouses_buf = n_warehouses; - n_warehouses_len = 4; - - ret = SQLBindParameter(populate_query, 2, SQL_PARAM_INPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&n_customers_d_buf, - 4, &n_customers_d_len); - ut_a(ret == SQL_SUCCESS); - - n_customers_d_buf = n_customers_d; - n_customers_d_len = 4; - - ret = SQLExecute(populate_query); - - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - printf("TPC-C test database initialized\n"); - - return(0); -} - -/********************************************************************* -Iterates an SQL query until it returns SQL_SUCCESS. If it returns other -value, rolls back the trx, prints an error message, and tries again. */ - -void -execute_until_success( -/*==================*/ - HSTMT query, /* in: query */ - HSTMT rollback_query) /* in: trx rollback query to run if error */ -{ - RETCODE ret; - UCHAR sql_state[6]; - SDWORD native_error; - UCHAR error_msg[512]; - SWORD error_msg_max = 512; - SWORD error_msg_len; - - for (;;) { - ret = SQLExecute(query); - - if (ret != SQL_SUCCESS) { - ut_a(ret == SQL_ERROR); - - ret = SQLError(SQL_NULL_HENV, SQL_NULL_HDBC, query, - sql_state, &native_error, error_msg, - error_msg_max, &error_msg_len); - - ut_a(ret == SQL_SUCCESS); - - printf("%s\n", error_msg); - - /* Roll back to release trx locks, and try again */ - - ret = SQLExecute(rollback_query); - ut_a(ret == SQL_SUCCESS); - - os_thread_sleep(ut_rnd_gen_ulint() / 1000); - } else { - - return; - } - } -} - -/********************************************************************* -Test for TPC-C. */ - -ulint -test_client( -/*=========*/ - void* arg) /* in: user name as a null-terminated string */ -{ - ulint n_customers = 20; - ulint n_items = 200; - ulint n_lines; - bool put_invalid_item; - HENV env; - HDBC conn; - RETCODE ret; - HSTMT commit_query; - HSTMT new_order_query; - HSTMT payment_query; - HSTMT order_status_query; - HSTMT delivery_query; - HSTMT stock_level_query; - HSTMT print_query; - HSTMT lock_wait_query; - HSTMT join_test_query; - HSTMT test_group_commit_query; - HSTMT rollback_query; - HSTMT ibuf_query; - ulint tm, oldtm; - char* str; - byte c_w_id_buf[2]; - byte c_d_id_buf[1]; - byte c_id_buf[3]; - byte ol_supply_w_ids_buf[30]; - byte ol_i_ids_buf[45]; - byte ol_quantities_buf[15]; - byte c_last_buf[51]; - byte c_credit_buf[3]; - ulint c_discount_buf; - ulint w_tax_buf; - ulint d_tax_buf; - ulint o_ol_count_buf; - ulint o_id_buf; - ulint o_entry_d_buf; - ulint total_buf; - byte i_names_buf[361]; - byte s_quantities_buf[60]; - byte bg_buf[16]; - byte i_prices_buf[60]; - byte ol_amounts_buf[60]; - SDWORD c_w_id_len; - SDWORD c_d_id_len; - SDWORD c_id_len; - SDWORD ol_supply_w_ids_len; - SDWORD ol_i_ids_len; - SDWORD ol_quantities_len; - SDWORD c_last_len; - SDWORD c_credit_len; - SDWORD c_discount_len; - SDWORD w_tax_len; - SDWORD d_tax_len; - SDWORD o_ol_count_len; - SDWORD o_id_len; - SDWORD o_entry_d_len; - SDWORD total_len; - SDWORD i_names_len; - SDWORD s_quantities_len; - SDWORD bg_len; - SDWORD i_prices_len; - SDWORD ol_amounts_len; - ulint i; - ulint k; - ulint t; - - printf("Client thread %s\n", (UCHAR*)arg); - - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &new_order_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &payment_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &order_status_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &delivery_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &stock_level_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &print_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &commit_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &lock_wait_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &join_test_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &test_group_commit_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &rollback_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &ibuf_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLConnect(conn, (UCHAR*)cli_srv_endpoint_name, - (SWORD)ut_strlen(cli_srv_endpoint_name), - (UCHAR*)arg, (SWORD)ut_strlen((char*)arg), - (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - /*-----------------------------------------------------------*/ - str = - "{NEW_ORDER(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?," - " ?, ?, ?, ?)}"; - - ret = SQLPrepare(new_order_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_w_id_buf, - 2, &c_w_id_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 2, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_d_id_buf, - 1, &c_d_id_len); - ut_a(ret == SQL_SUCCESS); - - c_d_id_len = 1; - - ret = SQLBindParameter(new_order_query, 3, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_id_buf, - 3, &c_id_len); - ut_a(ret == SQL_SUCCESS); - - c_id_len = 3; - - ret = SQLBindParameter(new_order_query, 4, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, ol_supply_w_ids_buf, - 30, &ol_supply_w_ids_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 5, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, ol_i_ids_buf, - 45, &ol_i_ids_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 6, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, ol_quantities_buf, - 15, &ol_quantities_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 7, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_last_buf, - 50, &c_last_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 8, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, - (byte*)&c_credit_buf, - 2, &c_credit_len); - ut_a(ret == SQL_SUCCESS); - c_credit_buf[2] = '\0'; - - ret = SQLBindParameter(new_order_query, 9, SQL_PARAM_OUTPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&c_discount_buf, - 4, &c_discount_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 10, SQL_PARAM_OUTPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&w_tax_buf, - 4, &w_tax_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 11, SQL_PARAM_OUTPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&d_tax_buf, - 4, &d_tax_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 12, SQL_PARAM_OUTPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&o_ol_count_buf, - 4, &o_ol_count_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 13, SQL_PARAM_OUTPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&o_id_buf, - 4, &o_id_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 14, SQL_PARAM_OUTPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&o_entry_d_buf, - 4, &o_entry_d_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 15, SQL_PARAM_OUTPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)&total_buf, - 4, &total_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 16, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, i_names_buf, - 360, &i_names_len); - ut_a(ret == SQL_SUCCESS); - i_names_buf[360] = '\0'; - - ret = SQLBindParameter(new_order_query, 17, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, s_quantities_buf, - 60, &s_quantities_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 18, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, bg_buf, - 15, &bg_len); - ut_a(ret == SQL_SUCCESS); - bg_buf[15] = '\0'; - - ret = SQLBindParameter(new_order_query, 19, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, i_prices_buf, - 60, &i_prices_len); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(new_order_query, 20, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, ol_amounts_buf, - 60, &ol_amounts_len); - ut_a(ret == SQL_SUCCESS); - - c_w_id_len = 2; - c_w_id_buf[1] = (byte)(2 * atoi((char*)arg + 4)); - c_w_id_buf[0] = (byte)(2 * (atoi((char*)arg + 4) / 256)); - - k = atoi((char*)arg + 4); - - printf("Client thread %lu starts\n", k); - - /*-----------------------------------------------------------*/ - str = "{PAYMENT(?)}"; - - ret = SQLPrepare(payment_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(payment_query, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_w_id_buf, - 2, &c_w_id_len); - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - str = "{ORDER_STATUS(?)}"; - - ret = SQLPrepare(order_status_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(order_status_query, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_w_id_buf, - 2, &c_w_id_len); - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - str = "{DELIVERY(?)}"; - - ret = SQLPrepare(delivery_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(delivery_query, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_w_id_buf, - 2, &c_w_id_len); - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - str = "{STOCK_LEVEL(?)}"; - - ret = SQLPrepare(stock_level_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(stock_level_query, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, c_w_id_buf, - 2, &c_w_id_len); - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - str = "{ROLLBACK_QUERY()}"; - - ret = SQLPrepare(rollback_query, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - /*-----------------------------------------------------------*/ - - oldtm = ut_clock(); - - for (i = k; i < k + n_rounds / n_users; i++) { - - /* execute_until_success(ibuf_query, rollback_query); */ - - if (i % 100 == 0) { - printf("User %s round %lu\n", (char*)arg, i); - } - - if (!own_warehouse) { - c_w_id_buf[1] = (byte)ut_rnd_interval(1, n_warehouses); - c_w_id_buf[0] = (byte)(ut_rnd_interval(1, n_warehouses) - / 256); - } - - mach_write_to_1(c_d_id_buf, (ut_rnd_interval(1, 10) + 47)); - mach_write_to_3(c_id_buf, ut_rnd_interval(1, n_customers)); - - n_lines = ut_rnd_interval(5, 15); - - if ((15 * k + i) % 100 == 0) { - put_invalid_item = TRUE; - - /* printf("Will put invalid item\n"); */ - } else { - put_invalid_item = FALSE; - } - - for (t = 0; t < n_lines; t++) { - mach_write_to_3(ol_i_ids_buf + 3 * t, - ut_rnd_interval(1, n_items)); - - if (put_invalid_item && (t + 1 == n_lines)) { - mach_write_to_3(ol_i_ids_buf + 3 * t, - n_items + 1); - } - - mach_write_to_1(ol_quantities_buf + t, - ut_rnd_interval(10, 20)); - ut_memcpy(ol_supply_w_ids_buf + 2 * t, c_w_id_buf, 2); - } - - ol_i_ids_len = 3 * n_lines; - ol_quantities_len = n_lines; - ol_supply_w_ids_len = 2 * n_lines; - - execute_until_success(new_order_query, rollback_query); - - if (put_invalid_item) { - - goto skip_prints; - } -/* - c_last_buf[c_last_len] = '\0'; - - printf( - "C_LAST %s, c_credit %s, c_discount, %lu, w_tax %lu, d_tax %lu\n", - c_last_buf, c_credit_buf, w_tax_buf, d_tax_buf); - - printf("o_ol_count %lu, o_id %lu, o_entry_d %lu, total %lu\n", - o_ol_count_buf, o_id_buf, o_entry_d_buf, - total_buf); - - ut_a(c_credit_len == 2); - ut_a(c_discount_len == 4); - ut_a(i_names_len == 360); - - printf("i_names %s, bg %s\n", i_names_buf, bg_buf); - - for (t = 0; t < n_lines; t++) { - printf("s_quantity %lu, i_price %lu, ol_amount %lu\n", - mach_read_from_4(s_quantities_buf + 4 * t), - mach_read_from_4(i_prices_buf + 4 * t), - mach_read_from_4(ol_amounts_buf + 4 * t)); - } -*/ - skip_prints: - ; - - execute_until_success(payment_query, rollback_query); - - if (i % 10 == 3) { - execute_until_success(order_status_query, - rollback_query); - } - - if ((i % 10 == 6) || (i % 100 == 60)) { - execute_until_success(delivery_query, rollback_query); - } - - if (i % 10 == 9) { - execute_until_success(stock_level_query, - rollback_query); - } - } - - tm = ut_clock(); - - printf("Wall time for %lu loops %lu milliseconds\n", - (i - k), tm - oldtm); - -/* execute_until_success(print_query, rollback_query); */ - - n_exited++; - - printf("Client thread %lu exits as the %luth\n", k, n_exited); - - return(0); -} - -/********************************************************************* -Test for single row select. */ - -ulint -test_single_row_select( -/*===================*/ - void* arg) /* in: user name as a null-terminated string */ -{ - ulint n_items = 200; - HENV env; - HDBC conn; - RETCODE ret; - HSTMT single_row_select_query; - ulint tm, oldtm; - char* str; - byte i_id_buf[3]; - byte i_name_buf[25]; - SDWORD i_id_len; - SDWORD i_name_len; - ulint i; - - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn, &single_row_select_query); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLConnect(conn, (UCHAR*)cli_srv_endpoint_name, - (SWORD)ut_strlen(cli_srv_endpoint_name), - (UCHAR*)arg, - (SWORD)ut_strlen((char*)arg), - (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - /*-----------------------------------------------------------*/ - str = - "{TEST_SINGLE_ROW_SELECT(?, ?)}"; - - ret = SQLPrepare(single_row_select_query, (UCHAR*)str, - ut_strlen(str)); - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(single_row_select_query, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, i_id_buf, - 3, &i_id_len); - ut_a(ret == SQL_SUCCESS); - i_id_len = 3; - - ret = SQLBindParameter(single_row_select_query, 2, SQL_PARAM_OUTPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, i_name_buf, - 24, &i_name_len); - ut_a(ret == SQL_SUCCESS); - i_name_buf[24] = '\0'; - - oldtm = ut_clock(); - - for (i = 0; i < 10000; i++) { - - mach_write_to_3(i_id_buf, ut_rnd_interval(1, n_items)); - - ret = SQLExecute(single_row_select_query); - - ut_a(ret == SQL_SUCCESS); - } - - tm = ut_clock(); - - printf("Wall time for %lu single row selects %lu milliseconds\n", - i, tm - oldtm); - return(0); -} - -/********************************************************************* -TPC-D query 5. */ - -ulint -test_tpc_d_client( -/*==============*/ - void* arg) /* in: pointer to an array of startdate and enddate */ -{ - char buf[20]; - HENV env; - HDBC conn1; - RETCODE ret; - HSTMT query5; - HSTMT join_test; - char* str; - SDWORD len1; - SDWORD len2; - ulint i; - ulint tm, oldtm; - - UT_NOT_USED(arg); - - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn1); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn1, &query5); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn1, &join_test); - - ut_a(ret == SQL_SUCCESS); - - sprintf(buf, "Use2%5lu", *((ulint*)arg)); - - ret = SQLConnect(conn1, (UCHAR*)cli_srv_endpoint_name, - (SWORD)ut_strlen(cli_srv_endpoint_name), - (UCHAR*)buf, - (SWORD)9, (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - /*-----------------------------------------------------------*/ - str = "{TPC_D_QUERY_5(?, ?)}"; - - ret = SQLPrepare(query5, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(query5, 1, SQL_PARAM_INPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)arg, - 4, &len1); - ut_a(ret == SQL_SUCCESS); - - len1 = 4; - - ret = SQLBindParameter(query5, 2, SQL_PARAM_INPUT, - SQL_C_LONG, SQL_INTEGER, 0, 0, - (byte*)arg + sizeof(ulint), - 4, &len2); - ut_a(ret == SQL_SUCCESS); - - len2 = 4; - - str = "{JOIN_TEST()}"; - - ret = SQLPrepare(join_test, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - for (i = 0; i < n_rounds; i++) { - - oldtm = ut_clock(); - - ret = SQLExecute(query5); - - /* ret = SQLExecute(join_test); */ - - ut_a(ret == SQL_SUCCESS); - - tm = ut_clock(); - - printf("Wall time %lu milliseconds\n", tm - oldtm); - } - - printf("%s exits\n", buf); - - return(0); -} - -/********************************************************************* -Checks consistency of the TPC databases. */ - -ulint -check_tpc_consistency( -/*==================*/ - void* arg) /* in: user name */ -{ - HENV env; - HDBC conn1; - RETCODE ret; - HSTMT consistency_query1; - char* str; - - UT_NOT_USED(arg); - - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn1); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn1, &consistency_query1); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLConnect(conn1, (UCHAR*)cli_srv_endpoint_name, - (SWORD)ut_strlen(cli_srv_endpoint_name), - (UCHAR*)arg, - (SWORD)ut_strlen((char*)arg), (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - /*-----------------------------------------------------------*/ - str = "{TPC_CONSISTENCY()}"; - - ret = SQLPrepare(consistency_query1, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLExecute(consistency_query1); - - ut_a(ret == SQL_SUCCESS); - - printf("Consistency checked\n"); - - return(0); -} - -/********************************************************************* -Test for errors. */ - -ulint -test_client_errors2( -/*================*/ - void* arg) /* in: ignored */ -{ - HENV env; - HDBC conn1; - RETCODE ret; - HSTMT error_test_query1; - char* str; - byte buf1[2]; - SDWORD len1; - UCHAR sql_state[6]; - SDWORD native_error; - UCHAR error_msg[512]; - SWORD error_msg_max = 512; - SWORD error_msg_len; - - UT_NOT_USED(arg); - - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn1); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn1, &error_test_query1); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLConnect(conn1, (UCHAR*)cli_srv_endpoint_name, - (SWORD)ut_strlen(cli_srv_endpoint_name), - (UCHAR*)"conn2", - (SWORD)5, (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - /*-----------------------------------------------------------*/ - str = "{TEST_ERRORS(?)}"; - - ret = SQLPrepare(error_test_query1, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(error_test_query1, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, buf1, - 2, &len1); - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - - printf("Thread 2 to do update\n"); - - ut_memcpy(buf1, "06", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_SUCCESS); - - printf("Thread 2 has done update\n"); - - ret = SQLError(SQL_NULL_HENV, SQL_NULL_HDBC, error_test_query1, - sql_state, &native_error, error_msg, error_msg_max, - &error_msg_len); - - ut_a(ret == SQL_NO_DATA_FOUND); - - return(0); -} - -/********************************************************************* -Test for errors. */ - -ulint -test_client_errors( -/*===============*/ - void* arg) /* in: ignored */ -{ - HENV env; - HDBC conn1; - RETCODE ret; - HSTMT error_test_query1; - char* str; - byte buf1[2]; - SDWORD len1; - UCHAR sql_state[6]; - SDWORD native_error; - UCHAR error_msg[512]; - SWORD error_msg_max = 512; - SWORD error_msg_len; - os_thread_id_t thread_id; - - UT_NOT_USED(arg); - - ret = SQLAllocEnv(&env); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocConnect(env, &conn1); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLAllocStmt(conn1, &error_test_query1); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLConnect(conn1, (UCHAR*)"innobase", 8, (UCHAR*)"conn1", - (SWORD)5, (UCHAR*)"password", 8); - ut_a(ret == SQL_SUCCESS); - - printf("Connection established\n"); - - /*-----------------------------------------------------------*/ - str = "{TEST_ERRORS(?)}"; - - ret = SQLPrepare(error_test_query1, (UCHAR*)str, ut_strlen(str)); - - ut_a(ret == SQL_SUCCESS); - - ret = SQLBindParameter(error_test_query1, 1, SQL_PARAM_INPUT, - SQL_C_CHAR, SQL_CHAR, 0, 0, buf1, - 2, &len1); - ut_a(ret == SQL_SUCCESS); - - /*-----------------------------------------------------------*/ - - ut_memcpy(buf1, "01", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_SUCCESS); - - ut_memcpy(buf1, "02", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_ERROR); - - ret = SQLError(SQL_NULL_HENV, SQL_NULL_HDBC, error_test_query1, - sql_state, &native_error, error_msg, error_msg_max, - &error_msg_len); - - ut_a(ret == SQL_SUCCESS); - - printf("%s\n", error_msg); - - ret = SQLError(SQL_NULL_HENV, SQL_NULL_HDBC, error_test_query1, - sql_state, &native_error, error_msg, error_msg_max, - &error_msg_len); - - ut_a(ret == SQL_NO_DATA_FOUND); - - ut_memcpy(buf1, "03", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_SUCCESS); - - ut_memcpy(buf1, "01", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_ERROR); - - ret = SQLError(SQL_NULL_HENV, SQL_NULL_HDBC, error_test_query1, - sql_state, &native_error, error_msg, error_msg_max, - &error_msg_len); - - ut_a(ret == SQL_SUCCESS); - - printf("%s\n", error_msg); - - ut_memcpy(buf1, "03", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_SUCCESS); - - ut_memcpy(buf1, "04", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_ERROR); - - ret = SQLError(SQL_NULL_HENV, SQL_NULL_HDBC, error_test_query1, - sql_state, &native_error, error_msg, error_msg_max, - &error_msg_len); - - ut_a(ret == SQL_SUCCESS); - - printf("%s\n", error_msg); - - ut_memcpy(buf1, "03", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_SUCCESS); - - ut_memcpy(buf1, "05", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_SUCCESS); - - os_thread_create(&test_client_errors2, "user000", &thread_id); - - os_thread_sleep(5000000); - - ut_memcpy(buf1, "07", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_ERROR); - - ret = SQLError(SQL_NULL_HENV, SQL_NULL_HDBC, error_test_query1, - sql_state, &native_error, error_msg, error_msg_max, - &error_msg_len); - - ut_a(ret == SQL_SUCCESS); - - printf("%s\n", error_msg); - - printf("Thread 1 to commit\n"); - - ut_memcpy(buf1, "08", 2); - len1 = 2; - ret = SQLExecute(error_test_query1); - ut_a(ret == SQL_SUCCESS); - - return(0); -} - -/************************************************************************* -Simulates disk waits: if there are at least two threads active, -puts the current thread to wait for an event. If there is just the current -thread active and another thread doing a simulated disk wait, puts the -current thread to wait and releases another thread from wait, otherwise does -nothing */ - -void -srv_simulate_disk_wait(void) -/*========================*/ -{ - os_event_t event; - ulint wait_i; - ulint count; - bool found; - ulint rnd; - ulint i; - ulint j; - - mutex_enter(&kernel_mutex); - - srv_disk_rnd += 98687241; - - count = 0; - found = FALSE; - - for (i = 0; i < SRV_N_SIM_DISK_ARRAY; i++) { - - if (!srv_sim_disk[i].empty) { - - count++; - } - - if (!found && srv_sim_disk[i].empty) { - - srv_sim_disk[i].empty = FALSE; - event = srv_sim_disk[i].event; - - os_event_reset(event); - srv_sim_disk[i].event_set = FALSE; - - wait_i = i; - - found = TRUE; - } - } - - ut_a(found); - - if (srv_disk_n_active_threads == count + 1) { - /* We have to release a thread from the disk wait array */; - - rnd = srv_disk_rnd; - - for (i = rnd; i < SRV_N_SIM_DISK_ARRAY + rnd; i++) { - - j = i % SRV_N_SIM_DISK_ARRAY; - - if (!srv_sim_disk[j].empty - && !srv_sim_disk[j].event_set) { - - srv_sim_disk[j].event_set = TRUE; - os_event_set(srv_sim_disk[j].event); - - break; - } - } - } - - mutex_exit(&kernel_mutex); - - os_event_wait(event); - - mutex_enter(&kernel_mutex); - - srv_sim_disk[wait_i].empty = TRUE; - - mutex_exit(&kernel_mutex); -} - -/************************************************************************* -Releases a thread from the simulated disk wait array if there is any to -release. */ - -void -srv_simulate_disk_wait_release(void) -/*================================*/ -{ - ulint rnd; - ulint i; - ulint j; - - mutex_enter(&kernel_mutex); - - srv_disk_rnd += 98687241; - rnd = srv_disk_rnd; - - for (i = rnd; i < SRV_N_SIM_DISK_ARRAY + rnd; i++) { - - j = i % SRV_N_SIM_DISK_ARRAY; - - if (!srv_sim_disk[j].empty - && !srv_sim_disk[j].event_set) { - - srv_sim_disk[j].event_set = TRUE; - os_event_set(srv_sim_disk[j].event); - - break; - } - } - - mutex_exit(&kernel_mutex); -} - -/********************************************************************* -Test for many threads and disk waits. */ - -ulint -test_disk_waits( -/*============*/ - void* arg) /* in: ignored */ -{ - ulint i; - ulint tm, oldtm; - - UT_NOT_USED(arg); - - n_exited++; - - printf("Client thread starts as the %luth\n", n_exited); - - oldtm = ut_clock(); - - mutex_enter(&kernel_mutex); - srv_disk_n_active_threads++; - mutex_exit(&kernel_mutex); - - for (i = 0; i < 133; i++) { - ut_delay(500); - -/* os_thread_yield(); */ - -/* os_thread_sleep(10000); */ - - srv_simulate_disk_wait(); - } - - mutex_enter(&kernel_mutex); - srv_disk_n_active_threads--; - mutex_exit(&kernel_mutex); - - srv_simulate_disk_wait_release(); - - tm = ut_clock(); - - printf("Wall time for %lu loops %lu milliseconds\n", i, tm - oldtm); - - n_exited++; - - printf("Client thread exits as the %luth\n", n_exited); - - return(0); -} - -/************************************************************************* -Reads a keywords and a values from an initfile. In case of an error, exits -from the process. */ - -void -cli_read_initfile( -/*==============*/ - FILE* initfile) /* in: file pointer */ -{ - char str_buf[10000]; - ulint ulint_val; - - srv_read_init_val(initfile, FALSE, "SRV_ENDPOINT_NAME", str_buf, - &ulint_val); - ut_a(ut_strlen(str_buf) < COM_MAX_ADDR_LEN); - - ut_memcpy(cli_srv_endpoint_name, str_buf, COM_MAX_ADDR_LEN); - - srv_read_init_val(initfile, FALSE, "USER_NAME", str_buf, - &ulint_val); - ut_a(ut_strlen(str_buf) < COM_MAX_ADDR_LEN); - - ut_memcpy(cli_user_name, str_buf, COM_MAX_ADDR_LEN); - - srv_read_init_val(initfile, TRUE, "MEM_POOL_SIZE", str_buf, - &mem_pool_size); - - srv_read_init_val(initfile, TRUE, "N_WAREHOUSES", str_buf, - &n_warehouses); - - srv_read_init_val(initfile, TRUE, "N_CUSTOMERS_D", str_buf, - &n_customers_d); - - srv_read_init_val(initfile, TRUE, "IS_TPC_D", str_buf, - &is_tpc_d); - - srv_read_init_val(initfile, TRUE, "N_ROUNDS", str_buf, - &n_rounds); - - srv_read_init_val(initfile, TRUE, "N_USERS", str_buf, - &n_users); - - srv_read_init_val(initfile, TRUE, "STARTDATE", str_buf, - &startdate); - - srv_read_init_val(initfile, TRUE, "ENDDATE", str_buf, - &enddate); - - srv_read_init_val(initfile, TRUE, "OWN_WAREHOUSE", str_buf, - &own_warehouse); -} - -/************************************************************************* -*/ -void -cli_boot( -/*=====*/ - char* name) /* in: the initialization file name */ -{ - FILE* initfile; - - initfile = fopen(name, "r"); - - if (initfile == NULL) { - printf( - "Error in client booting: could not open initfile whose name is %s!\n", - name); - os_process_exit(1); - } - - cli_read_initfile(initfile); - - fclose(initfile); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - os_thread_t thread_handles[1000]; - os_thread_id_t thread_ids[1000]; - char user_names[1000]; - ulint tm, oldtm; - ulint i; - ulint dates[1000]; - - cli_boot("cli_init"); - - for (i = 1; i <= n_users; i++) { - dates[2 * i] = startdate - + ((enddate - startdate) / n_users) * (i - 1); - dates[2 * i + 1] = startdate - + ((enddate - startdate) / n_users) * i; - } - - sync_init(); - - mem_init(mem_pool_size); - - test_init(NULL); - - check_tpc_consistency("con21"); - -/* test_client_errors(NULL); */ - - os_thread_sleep(4000000); - - printf("Sleep ends\n"); - - oldtm = ut_clock(); - - for (i = 2; i <= n_users; i++) { - if (is_tpc_d) { - thread_handles[i] = os_thread_create(&test_tpc_d_client, - dates + 2 * i, thread_ids + i); - } else { - sprintf(user_names + i * 8, "use2%3lu", i); - - thread_handles[i] = os_thread_create(&test_client, - user_names + i * 8, thread_ids + i); - } - - ut_a(thread_handles[i]); - } - - if (is_tpc_d) { - test_tpc_d_client(dates + 2 * 1); - } else { - test_client("use2 1"); - } - - for (i = 2; i <= n_users; i++) { - os_thread_wait(thread_handles[i]); - - printf("Wait for thread %lu ends\n", i); - } - - tm = ut_clock(); - - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - os_thread_sleep(4000000); - - printf("Sleep ends\n"); - - test_single_row_select("con99"); - - check_tpc_consistency("con22"); - - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/tsrecv.c b/innobase/btr/ts/tsrecv.c deleted file mode 100644 index 0f30fcd94f1..00000000000 --- a/innobase/btr/ts/tsrecv.c +++ /dev/null @@ -1,4909 +0,0 @@ -/************************************************************************ -Test for the B-tree - -(c) 1994-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "os0proc.h" -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "mem0pool.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "os0thread.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "log0recv.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "btr0cur.h" -#include "btr0sea.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "trx0purge.h" -#include "row0ins.h" -#include "row0upd.h" -#include "row0row.h" -#include "row0del.h" -#include "lock0lock.h" -#include "ibuf0ibuf.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 3 /* must be >= 2 */ -#define N_FILES 1 -#define FILE_SIZE 512 /* must be > 512 */ -#define POOL_SIZE 1000 -#define IBUF_SIZE 200 -#define COUNTER_OFFSET 1500 - -#define N_LOG_GROUPS 2 -#define N_LOG_FILES 3 -#define LOG_FILE_SIZE 500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - -#define COUNT 1 - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -ulint dummy = 0; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - ulint i; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - fil_aio_wait(segment); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates or opens the log files. */ - -void -create_log_files(void) -/*==================*/ -{ - bool ret; - ulint i, k; - char name[20]; - - printf("--------------------------------------------------------\n"); - printf("Create or open log files\n"); - - strcpy(name, "logfile00"); - - for (k = 0; k < N_LOG_GROUPS; k++) { - for (i = 0; i < N_LOG_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, OS_FILE_AIO, - &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_AIO, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - 8192 * LOG_FILE_SIZE, 0)); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k + 100, FIL_LOG); - } - - ut_a(fil_validate()); - - fil_node_create(name, LOG_FILE_SIZE, k + 100); - } - - fil_space_create(name, k + 200, FIL_LOG); - - log_group_init(k, N_LOG_FILES, LOG_FILE_SIZE * UNIV_PAGE_SIZE, - k + 100, k + 200); - } -} - -/************************************************************************* -Creates the files for the file system test and inserts them to the file -system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[10]; - os_thread_id_t id[10]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < 2 * N_SPACES; k += 2) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_AIO, &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_AIO, &ret); - ut_a(ret); - } else { - if (k == 1) { - ut_a(os_file_set_size(files[i], - 8192 * IBUF_SIZE, 0)); - } else { - ut_a(os_file_set_size(files[i], - 8192 * FILE_SIZE, 0)); - } - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, FIL_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - mutex_set_level(&ios_mutex, SYNC_NO_ORDER_CHECK); - - for (i = 0; i < 9; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/********************************************************************* -Test for table creation. */ - -ulint -test1( -/*==*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND1", 0, - DICT_UNIQUE | DICT_CLUSTERED, 1); - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -#ifdef notdefined - /*-------------------------------------*/ - /* CREATE YET ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND4", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -#endif -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_5( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.5. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE2", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE2", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_6( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.6. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE3", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE3", "IND1", 0, DICT_CLUSTERED, - 2); - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_7( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.7. CREATE TABLE WITH 12 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE4", 0, 12); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL4", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL5", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL6", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL7", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL8", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL9", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL10", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL11", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL12", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE4", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Test for inserts. */ - -ulint -test2( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - dict_index_t* index; -/* ulint size; */ - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2. MASSIVE INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - /* MASSIVE RANDOM INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 7857641) % 200000; - - dtuple_gen_test_tuple3(row, rnd, - DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 1000 == 0) { - printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); -/* - for (i = 0; i < 10; i++) { - size = ibuf_contract(TRUE); - - printf("%lu bytes will be contracted\n", size); - - os_thread_sleep(1000000); - } -*/ - index = dict_table_get_next_index(dict_table_get_first_index(table)); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - index = dict_table_get_next_index(index); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - btr_search_print_info(); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 7857641) % 200000; - dtuple_gen_search_tuple3(entry, rnd, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); - -/* btr_print_tree(tree, 5); */ - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - btr_validate_tree(tree); - -/* btr_search_print_info(); - dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_1( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ins_node_t* node; - ulint count = 0; - ulint rnd; - dtuple_t* row; -/* dict_tree_t* tree; - dict_index_t* index; - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; */ - - printf("-------------------------------------------------\n"); - printf("TEST 2.1. MASSIVE ASCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - rnd = 0; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND3500, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 5000 == 0) { - /* ibuf_print(); */ - /* buf_print(); */ - - /* buf_print_io(); */ - - tm = ut_clock(); - /* - printf("Wall time for %lu inserts %lu milliseconds\n", - i, tm - oldtm); */ - } - - rnd = rnd + 1; - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined -/* dict_table_print_by_name("TS_TABLE1"); */ - - ibuf_print(); - - index = dict_table_get_first_index(table); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - /* Check inserted entries */ - - btr_search_print_info(); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); -#endif -#ifdef notdefined - /*-------------------------------------*/ - /* ROLLBACK */ - -/* btr_validate_tree(tree); */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_search_print_info(); - -#endif - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - /*-------------------------------------*/ - - count++; -/* btr_validate_tree(tree); */ - - if (count < 5) { - goto loop; - } - - mem_heap_free(heap); - - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_2( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2. MASSIVE DESCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = *((ulint*)arg) + 1; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 200000; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 1000 == 0) { -/* printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); */ - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i + 1, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_validate_tree(tree); -/* dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - btr_validate_tree(tree); - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Multithreaded test for random inserts. */ - -ulint -test2mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2MT. MULTITHREADED RANDOM INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - rnd = 78675; -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - if (i % 100 == 0) { -/* buf_print(); */ -/* ibuf_print(); */ - } - - rnd = (rnd + 7857641) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_1mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.1MT. MULTITHREADED ASCENDING INSERT\n"); - - rnd = 8757677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 98667501; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_2mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2MT. MULTITHREADED DESCENDING INSERT\n"); - - rnd = 87677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 78667; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - mem_print_info(); - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for updates. */ - -ulint -test3( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - byte* ptr; - ulint len; - ulint err; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 3. UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 3; i++) { - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* UPDATE ROWS */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - dtuple_gen_test_tuple3(row, 1, DTUPLE_TEST_RND30, buf); - - entry = dtuple_create(heap, 2); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - dfield_copy(dtuple_get_nth_field(entry, 1), - dtuple_get_nth_field(row, 1)); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), "updated field", 14); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - mtr_start(&mtr); - - ut_a(btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr)); - - ptr = rec_get_nth_field(btr_pcur_get_rec(&pcur), 5, &len); - - ut_a(ut_memcmp(ptr, "updated field", 14) == 0); - - btr_pcur_commit(&pcur); - - dict_table_print_by_name("TS_TABLE1"); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - dfield_set_data(&(ufield->new_val), "31415926", 9); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* ROLLBACK */ -#ifdef notdefined - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ -#endif - dict_table_print_by_name("TS_TABLE1"); - count++; - - if (count < 1) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Init for update test. */ - -ulint -test4_1(void) -/*=========*/ -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - - printf("-------------------------------------------------\n"); - printf("TEST 4.1. UPDATE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/************************************************************************* -Checks that the multithreaded update test has rolled back its updates. */ - -void -test4_2(void) -/*=========*/ -{ - dtuple_t* entry; - mem_heap_t* heap; - mem_heap_t* heap2; - mtr_t mtr; - byte buf[32]; - sess_t* sess; - com_endpoint_t* com_endpoint; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - btr_pcur_t pcur; - rec_t* rec; - - printf("-------------------------------------------------\n"); - printf("TEST 4.2. CHECK UPDATE RESULT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*------------------------------------------*/ - - table = dict_table_get("TS_TABLE1", trx); - - index = dict_table_get_first_index(table); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < 200; i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - rec = btr_pcur_get_rec(&pcur); - - ut_a(0 == cmp_dtuple_rec(entry, rec)); - - heap2 = mem_heap_create(200); - - row = row_build(ROW_COPY_DATA, index, rec, heap2); - - ut_a(30 == dfield_get_len(dtuple_get_nth_field(row, 2))); - ut_a(0 == ut_memcmp( - dfield_get_data(dtuple_get_nth_field(row, 2)), - "12345678901234567890123456789", 30)); - - mem_heap_free(heap2); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -} - -/********************************************************************* -Test for massive updates. */ - -ulint -test4mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 4. MULTITHREADED UPDATES\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 300; i++) { - - rnd += 874681; - tuple_no = (rnd % 40) * 5 + thr_no; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 3000); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(2000000); - - btr_validate_tree(tree); - - ut_a(trx->conc_state != TRX_ACTIVE); - ut_a(UT_LIST_GET_LEN(trx->trx_locks) == 0); - - count++; - - if (count < 2) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for join. */ - -ulint -test6( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ulint count = 0; - dtuple_t* entry; - dict_index_t* index; - dict_tree_t* tree; - btr_pcur_t pcur; - btr_pcur_t pcur2; - mtr_t mtr; - mtr_t mtr2; - ulint rnd; - ulint latch_mode; - - printf("-------------------------------------------------\n"); - printf("TEST 6. MASSIVE EQUIJOIN\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*--------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - /*--------------*/ - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - table = dict_table_get("TS_TABLE1", trx); - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - oldtm = ut_clock(); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IS, thr)); - - rnd = 98651; - - for (i = 0; i < *((ulint*)arg); i++) { - - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - btr_pcur_store_position(&pcur, &mtr); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); - - btr_pcur_commit_specify_mtr(&pcur, &mtr); - - if (i % 1211 == 0) { - dummy++; - } - - rnd = 55321; - - dtuple_gen_search_tuple3(entry, rnd % *((ulint*)arg), buf); - -/* if (i == 0) { */ - latch_mode = BTR_SEARCH_LEAF; -/* } else { - latch_mode = BTR_SEARCH_LEAF | BTR_GUESS_LATCH; - } */ - - mtr_start(&mtr2); - - btr_pcur_open(index, entry, PAGE_CUR_LE, latch_mode, - &pcur2, &mtr2); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur2), - index)); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur2))); - - mtr_commit(&mtr2); - - mtr_start(&mtr); - - btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - tm = ut_clock(); - printf("Wall time for join of %lu rows %lu milliseconds\n", - i, tm - oldtm); - btr_search_index_print_info(index); - /*-------------------------------------*/ - /* COMMIT */ - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); -/* printf("Wall time for commit %lu milliseconds\n", tm - oldtm); */ - - /*-------------------------------------*/ - count++; -/* btr_validate_tree(tree); */ - - if (count < 3) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for lock wait. Requires Test 4.1 first. */ - -ulint -test7( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - trx_t* trx2; - ulint rnd; - dtuple_t* entry; - dtuple_t* row; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 7. LOCK WAIT\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx2 = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - /* UPDATE by trx */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - ut_a(trx_start(trx2, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 2); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - rnd += 874681; - tuple_no = 3; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 1500); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - tm = ut_clock(); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* INSERT by trx2 */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx2; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx2); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx2->sess); - - trx2->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - dtuple_gen_test_tuple3(row, 2, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - /* Insert should be left to wait until trx releases the row lock */ - - que_run_threads(thr); - - tm = ut_clock(); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* COMMIT of trx */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - - /*-------------------------------------*/ - os_thread_sleep(1000000); - - printf( - "trx2 can now continue to do the insert, after trx committed.\n"); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/********************************************************************* -Inserts for TPC-A. */ - -ulint -test8A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 8A. 1000 INSERTS FOR TPC-A\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE2", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 1000; i++) { - dtuple_gen_test_tuple_TPC_A(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < 1000; i++) { - dtuple_gen_search_tuple_TPC_A(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE2"); */ - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for TPC-A transaction. */ - -ulint -test8( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 8. TPC-A %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE2", trx); - - update = upd_create(1, heap); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); - -loop: -/* printf("Round %lu\n", count); */ - - /*-------------------------------------*/ - /* INSERT */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - /*-------------------------------------*/ - /* 3 UPDATES */ - - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - - for (i = 0; i < 3; i++) { - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_A(entry, rnd % 1000, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - -/* ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); */ - -/* btr_pcur_store_position(&pcur, &mtr); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - tm = ut_clock(); - printf("Wall time for TPC-A %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ - - -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Inserts for TPC-C. */ - -ulint -test9A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; -/* dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - dict_index_t* index; - dict_tree_t* tree; -*/ - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 9A. INSERTS FOR TPC-C\n"); - -#define TPC_C_TABLE_SIZE 15000 - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE4", trx); - - row = dtuple_create(heap, 12 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_test_tuple_TPC_C(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_search_tuple_TPC_C(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); -#endif - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE4"); */ - -/* mem_heap_free(heap); */ - return(0); -} - -/********************************************************************* -Test for TPC-C transaction. Test 9A must be run first to populate table. */ - -ulint -test9( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint j; - ulint i; - byte* ptr; - ulint len; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - byte buf2[240]; - rec_t* rec; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 9. TPC-C %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE4", trx); - - update = upd_create(3, heap); - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 2); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); -loop: - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IS, thr)); - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - -/* printf("Round %lu\n", count); */ - -for (j = 0; j < 13; j++) { - - /*-------------------------------------*/ - /* SELECT FROM 'ITEM' */ - - rnd += 876751; - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_S, thr); - ut_a(err == DB_SUCCESS); - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 5; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* UPDATE 'STOCK' */ - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - -/* btr_pcur_store_position(&pcur, &mtr); */ - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 10; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - -/* btr_pcur_commit(&pcur); */ - -/* err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); */ - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); -/* ut_a(err == DB_SUCCESS); */ - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 1); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 2); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - btr_pcur_close(&pcur); - /*-------------------------------------*/ - /* INSERT INTO 'ORDERLINE' */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count * 13 + j, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -} - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - - tm = ut_clock(); - printf("Wall time for TPC-C %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Init for purge test. */ - -ulint -test10_1( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.1. PURGE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i * 100 + thr_no, - DTUPLE_TEST_FIXED30, buf); - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 200); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2_r( -/*=======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 2000); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(2000000); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_3( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.3. PURGE TEST DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - rnd = i; - tuple_no = rnd; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_5( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.5. PURGE TEST UNCOMMITTED DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 50; i++) { - - rnd = i; - tuple_no = rnd % 100; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - return(0); -} - -/********************************************************************* -Multithreaded test for purge. */ - -ulint -test10mt( -/*=====*/ - void* arg) -{ - ulint i; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("Thread %lu starts purge test\n", thr_no); - - for (i = 0; i < 2; i++) { - test10_1(arg); - - sync_print(); - - fsp_validate(0); - - test10_2_r(arg); - sync_print(); - - test10_2(arg); - sync_print(); - - lock_validate(); - - test10_3(arg); - sync_print(); - } - - printf("Thread %lu ends purge test\n", thr_no); - - return(0); -} - -/********************************************************************* -Purge test. */ - -ulint -test10_4( -/*=====*/ - void* arg) -{ - ulint i; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.4. PURGE TEST\n"); - - for (i = 0; i < 30; i++) { - trx_purge(); - - printf("%lu pages purged\n", purge_sys->n_pages_handled); - - os_thread_sleep(5000000); - } - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -This thread is used to test insert buffer merge. */ - -ulint -test_ibuf_merge( -/*============*/ - void* arg) -{ - ulint sum_sizes; - ulint volume; - - ut_ad(arg); - - printf("Starting ibuf merge\n"); - - sum_sizes = 0; - volume = 1; - - while (volume) { - volume = ibuf_contract(FALSE); - - sum_sizes += volume; - } - - printf("Ibuf merged %lu bytes\n", sum_sizes); - - os_thread_sleep(5000000); - - return(0); -} - -/********************************************************************* -This thread is used to measure contention of latches. */ - -ulint -test_measure_cont( -/*==============*/ - void* arg) -{ - ulint i, j; - ulint count; - - ut_ad(arg); - - printf("Starting contention measurement\n"); - - for (i = 0; i < 1000; i++) { - count = 0; - - for (j = 0; j < 100; j++) { - - os_thread_sleep(10000); - - if ((&(buf_pool->mutex))->lock_word) { - - count++; - } - } - - printf("Mutex reserved %lu of %lu peeks\n", count, j); - } - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - ulint n5000 = 500; - ulint err; - - oldtm = ut_clock(); - -/* buf_debug_prints = TRUE; */ - log_do_write = TRUE; - log_debug_writes = FALSE; -/* btr_search_use_hash = FALSE; */ - - srv_boot("initfile"); - os_aio_init(576, 9, 100); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - lock_sys_create(1024); - - create_files(); - create_log_files(); - - sess_sys_init_at_db_start(); - - mem_validate(); - - /* Tests crash recovery: */ -/* - err = recv_recovery_from_checkpoint_start(LOG_CHECKPOINT, - ut_dulint_max); - ut_a(err == DB_SUCCESS); - - recv_compare_spaces_low(0, 4, 100); - - trx_sys_init_at_db_start(); - - dict_boot(); - - recv_recovery_from_checkpoint_finish(); -*/ - /* Tests archive recovery: */ - - err = recv_recovery_from_archive_start(ut_dulint_max, - "ib_arch_log_0_0000000000"); - ut_a(err == DB_SUCCESS); - - recv_compare_spaces_low(0, 4, 500); - - trx_sys_init_at_db_start(); - - dict_boot(); - - recv_recovery_from_archive_finish(); - -/* test4_2(); */ - - log_make_checkpoint_at(ut_dulint_max); - -/* dict_table_print_by_name("SYS_TABLES"); - - dict_table_print_by_name("SYS_COLUMNS"); - - dict_table_print_by_name("SYS_INDEXES"); */ - - dict_table_print_by_name("TS_TABLE1"); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/tsrecv97.c b/innobase/btr/ts/tsrecv97.c deleted file mode 100644 index 0f30fcd94f1..00000000000 --- a/innobase/btr/ts/tsrecv97.c +++ /dev/null @@ -1,4909 +0,0 @@ -/************************************************************************ -Test for the B-tree - -(c) 1994-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "os0proc.h" -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "mem0pool.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "os0thread.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "log0recv.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "btr0cur.h" -#include "btr0sea.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "trx0purge.h" -#include "row0ins.h" -#include "row0upd.h" -#include "row0row.h" -#include "row0del.h" -#include "lock0lock.h" -#include "ibuf0ibuf.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 3 /* must be >= 2 */ -#define N_FILES 1 -#define FILE_SIZE 512 /* must be > 512 */ -#define POOL_SIZE 1000 -#define IBUF_SIZE 200 -#define COUNTER_OFFSET 1500 - -#define N_LOG_GROUPS 2 -#define N_LOG_FILES 3 -#define LOG_FILE_SIZE 500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - -#define COUNT 1 - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -ulint dummy = 0; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - ulint i; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - fil_aio_wait(segment); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates or opens the log files. */ - -void -create_log_files(void) -/*==================*/ -{ - bool ret; - ulint i, k; - char name[20]; - - printf("--------------------------------------------------------\n"); - printf("Create or open log files\n"); - - strcpy(name, "logfile00"); - - for (k = 0; k < N_LOG_GROUPS; k++) { - for (i = 0; i < N_LOG_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, OS_FILE_AIO, - &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_AIO, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - 8192 * LOG_FILE_SIZE, 0)); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k + 100, FIL_LOG); - } - - ut_a(fil_validate()); - - fil_node_create(name, LOG_FILE_SIZE, k + 100); - } - - fil_space_create(name, k + 200, FIL_LOG); - - log_group_init(k, N_LOG_FILES, LOG_FILE_SIZE * UNIV_PAGE_SIZE, - k + 100, k + 200); - } -} - -/************************************************************************* -Creates the files for the file system test and inserts them to the file -system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[10]; - os_thread_id_t id[10]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < 2 * N_SPACES; k += 2) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_AIO, &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_AIO, &ret); - ut_a(ret); - } else { - if (k == 1) { - ut_a(os_file_set_size(files[i], - 8192 * IBUF_SIZE, 0)); - } else { - ut_a(os_file_set_size(files[i], - 8192 * FILE_SIZE, 0)); - } - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, FIL_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - mutex_set_level(&ios_mutex, SYNC_NO_ORDER_CHECK); - - for (i = 0; i < 9; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/********************************************************************* -Test for table creation. */ - -ulint -test1( -/*==*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND1", 0, - DICT_UNIQUE | DICT_CLUSTERED, 1); - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -#ifdef notdefined - /*-------------------------------------*/ - /* CREATE YET ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND4", 0, 0, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -#endif -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_5( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.5. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE2", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE2", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_6( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.6. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE3", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE3", "IND1", 0, DICT_CLUSTERED, - 2); - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_7( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.7. CREATE TABLE WITH 12 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE4", 0, 12); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL4", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL5", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL6", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL7", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL8", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL9", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL10", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL11", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - dict_mem_table_add_col(table, "COL12", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE4", "IND1", 0, - DICT_CLUSTERED | DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Test for inserts. */ - -ulint -test2( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - dict_index_t* index; -/* ulint size; */ - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2. MASSIVE INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - /* MASSIVE RANDOM INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 7857641) % 200000; - - dtuple_gen_test_tuple3(row, rnd, - DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 1000 == 0) { - printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); -/* - for (i = 0; i < 10; i++) { - size = ibuf_contract(TRUE); - - printf("%lu bytes will be contracted\n", size); - - os_thread_sleep(1000000); - } -*/ - index = dict_table_get_next_index(dict_table_get_first_index(table)); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - index = dict_table_get_next_index(index); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - btr_search_print_info(); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 7857641) % 200000; - dtuple_gen_search_tuple3(entry, rnd, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); - -/* btr_print_tree(tree, 5); */ - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - btr_validate_tree(tree); - -/* btr_search_print_info(); - dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_1( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ins_node_t* node; - ulint count = 0; - ulint rnd; - dtuple_t* row; -/* dict_tree_t* tree; - dict_index_t* index; - dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; */ - - printf("-------------------------------------------------\n"); - printf("TEST 2.1. MASSIVE ASCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - rnd = 0; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND3500, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 5000 == 0) { - /* ibuf_print(); */ - /* buf_print(); */ - - /* buf_print_io(); */ - - tm = ut_clock(); - /* - printf("Wall time for %lu inserts %lu milliseconds\n", - i, tm - oldtm); */ - } - - rnd = rnd + 1; - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined -/* dict_table_print_by_name("TS_TABLE1"); */ - - ibuf_print(); - - index = dict_table_get_first_index(table); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - - index = dict_table_get_next_index(index); - - btr_search_index_print_info(index); - - btr_validate_tree(dict_index_get_tree(index)); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - /* Check inserted entries */ - - btr_search_print_info(); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); -#endif -#ifdef notdefined - /*-------------------------------------*/ - /* ROLLBACK */ - -/* btr_validate_tree(tree); */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_search_print_info(); - -#endif - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - /*-------------------------------------*/ - - count++; -/* btr_validate_tree(tree); */ - - if (count < 5) { - goto loop; - } - - mem_heap_free(heap); - - return(0); -} - -/********************************************************************* -Another test for inserts. */ - -ulint -test2_2( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2. MASSIVE DESCENDING INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = *((ulint*)arg) + 1; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 200000; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - if (i % 1000 == 0) { -/* printf( - "********************************Inserted %lu rows\n", i); - ibuf_print(); */ - } - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < *((ulint*)arg); i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i + 1, buf); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - btr_validate_tree(tree); -/* dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(1000000); - - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - - btr_validate_tree(tree); - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Multithreaded test for random inserts. */ - -ulint -test2mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2MT. MULTITHREADED RANDOM INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - rnd = 78675; -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - if (i % 100 == 0) { -/* buf_print(); */ -/* ibuf_print(); */ - } - - rnd = (rnd + 7857641) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_1mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.1MT. MULTITHREADED ASCENDING INSERT\n"); - - rnd = 8757677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 98667501; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for multithreaded sequential inserts. */ - -ulint -test2_2mt( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2.2MT. MULTITHREADED DESCENDING INSERT\n"); - - rnd = 87677; - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - rnd += 78667; - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd - 1) % 500; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(3000000); - /*-------------------------------------*/ -#ifdef notdefined - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); -#endif - /*-------------------------------------*/ - count++; - - mem_print_info(); - - if (count < COUNT) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for updates. */ - -ulint -test3( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - byte* ptr; - ulint len; - ulint err; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 3. UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 3; i++) { - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_RND30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* UPDATE ROWS */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - dtuple_gen_test_tuple3(row, 1, DTUPLE_TEST_RND30, buf); - - entry = dtuple_create(heap, 2); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - dfield_copy(dtuple_get_nth_field(entry, 1), - dtuple_get_nth_field(row, 1)); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), "updated field", 14); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - mtr_start(&mtr); - - ut_a(btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr)); - - ptr = rec_get_nth_field(btr_pcur_get_rec(&pcur), 5, &len); - - ut_a(ut_memcmp(ptr, "updated field", 14) == 0); - - btr_pcur_commit(&pcur); - - dict_table_print_by_name("TS_TABLE1"); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - dfield_set_data(&(ufield->new_val), "31415926", 9); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* ROLLBACK */ -#ifdef notdefined - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ -#endif - dict_table_print_by_name("TS_TABLE1"); - count++; - - if (count < 1) { - goto loop; - } - - return(0); -} - -/********************************************************************* -Init for update test. */ - -ulint -test4_1(void) -/*=========*/ -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - - printf("-------------------------------------------------\n"); - printf("TEST 4.1. UPDATE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/************************************************************************* -Checks that the multithreaded update test has rolled back its updates. */ - -void -test4_2(void) -/*=========*/ -{ - dtuple_t* entry; - mem_heap_t* heap; - mem_heap_t* heap2; - mtr_t mtr; - byte buf[32]; - sess_t* sess; - com_endpoint_t* com_endpoint; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - btr_pcur_t pcur; - rec_t* rec; - - printf("-------------------------------------------------\n"); - printf("TEST 4.2. CHECK UPDATE RESULT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*------------------------------------------*/ - - table = dict_table_get("TS_TABLE1", trx); - - index = dict_table_get_first_index(table); - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - ut_a(btr_pcur_is_before_first_in_tree(&pcur, &mtr)); - - for (i = 0; i < 200; i++) { - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - dtuple_gen_search_tuple3(entry, i, buf); - - rec = btr_pcur_get_rec(&pcur); - - ut_a(0 == cmp_dtuple_rec(entry, rec)); - - heap2 = mem_heap_create(200); - - row = row_build(ROW_COPY_DATA, index, rec, heap2); - - ut_a(30 == dfield_get_len(dtuple_get_nth_field(row, 2))); - ut_a(0 == ut_memcmp( - dfield_get_data(dtuple_get_nth_field(row, 2)), - "12345678901234567890123456789", 30)); - - mem_heap_free(heap2); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); -} - -/********************************************************************* -Test for massive updates. */ - -ulint -test4mt( -/*====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 4. MULTITHREADED UPDATES\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 300; i++) { - - rnd += 874681; - tuple_no = (rnd % 40) * 5 + thr_no; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 3000); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(2000000); - - btr_validate_tree(tree); - - ut_a(trx->conc_state != TRX_ACTIVE); - ut_a(UT_LIST_GET_LEN(trx->trx_locks) == 0); - - count++; - - if (count < 2) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for join. */ - -ulint -test6( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - byte buf[100]; - ulint count = 0; - dtuple_t* entry; - dict_index_t* index; - dict_tree_t* tree; - btr_pcur_t pcur; - btr_pcur_t pcur2; - mtr_t mtr; - mtr_t mtr2; - ulint rnd; - ulint latch_mode; - - printf("-------------------------------------------------\n"); - printf("TEST 6. MASSIVE EQUIJOIN\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*--------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - /*--------------*/ - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /* Check inserted entries */ - - entry = dtuple_create(heap, 1); - dtuple_gen_search_tuple3(entry, 0, buf); - - mtr_start(&mtr); - - table = dict_table_get("TS_TABLE1", trx); - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - oldtm = ut_clock(); - - btr_pcur_open(index, entry, PAGE_CUR_L, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IS, thr)); - - rnd = 98651; - - for (i = 0; i < *((ulint*)arg); i++) { - - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - btr_pcur_store_position(&pcur, &mtr); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); - - btr_pcur_commit_specify_mtr(&pcur, &mtr); - - if (i % 1211 == 0) { - dummy++; - } - - rnd = 55321; - - dtuple_gen_search_tuple3(entry, rnd % *((ulint*)arg), buf); - -/* if (i == 0) { */ - latch_mode = BTR_SEARCH_LEAF; -/* } else { - latch_mode = BTR_SEARCH_LEAF | BTR_GUESS_LATCH; - } */ - - mtr_start(&mtr2); - - btr_pcur_open(index, entry, PAGE_CUR_LE, latch_mode, - &pcur2, &mtr2); - - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur2), - index)); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur2))); - - mtr_commit(&mtr2); - - mtr_start(&mtr); - - btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr); - } - - ut_a(!btr_pcur_move_to_next(&pcur, &mtr)); - ut_a(btr_pcur_is_after_last_in_tree(&pcur, &mtr)); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - - tm = ut_clock(); - printf("Wall time for join of %lu rows %lu milliseconds\n", - i, tm - oldtm); - btr_search_index_print_info(index); - /*-------------------------------------*/ - /* COMMIT */ - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); -/* printf("Wall time for commit %lu milliseconds\n", tm - oldtm); */ - - /*-------------------------------------*/ - count++; -/* btr_validate_tree(tree); */ - - if (count < 3) { - goto loop; - } - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for lock wait. Requires Test 4.1 first. */ - -ulint -test7( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - trx_t* trx2; - ulint rnd; - dtuple_t* entry; - dtuple_t* row; - byte buf[100]; - byte buf2[4000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 7. LOCK WAIT\n"); - - thr_no = *((ulint*)arg); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx2 = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - /* UPDATE by trx */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - ut_a(trx_start(trx2, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 2); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - rnd += 874681; - tuple_no = 3; - - dtuple_gen_search_tuple3(entry, tuple_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 2, table); - dfield_set_data(&(ufield->new_val), buf2, rnd % 1500); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - tm = ut_clock(); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* INSERT by trx2 */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx2; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx2); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx2->sess); - - trx2->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - dtuple_gen_test_tuple3(row, 2, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - /* Insert should be left to wait until trx releases the row lock */ - - que_run_threads(thr); - - tm = ut_clock(); - - lock_validate(); - - lock_print_info(); - - /*-------------------------------------*/ - /* COMMIT of trx */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - - /*-------------------------------------*/ - os_thread_sleep(1000000); - - printf( - "trx2 can now continue to do the insert, after trx committed.\n"); - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - - lock_validate(); - - lock_print_info(); - - dict_table_print_by_name("TS_TABLE1"); - - return(0); -} - -/********************************************************************* -Inserts for TPC-A. */ - -ulint -test8A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - dict_index_t* index; - dict_tree_t* tree; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - btr_pcur_t pcur; - mtr_t mtr; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 8A. 1000 INSERTS FOR TPC-A\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE2", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 1000; i++) { - dtuple_gen_test_tuple_TPC_A(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < 1000; i++) { - dtuple_gen_search_tuple_TPC_A(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); - - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE2"); */ - - mem_heap_free(heap); - return(0); -} - -/********************************************************************* -Test for TPC-A transaction. */ - -ulint -test8( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 8. TPC-A %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE2", trx); - - update = upd_create(1, heap); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); - -loop: -/* printf("Round %lu\n", count); */ - - /*-------------------------------------*/ - /* INSERT */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - /*-------------------------------------*/ - /* 3 UPDATES */ - - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - - for (i = 0; i < 3; i++) { - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_A(entry, rnd % 1000, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - -/* ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); */ - -/* btr_pcur_store_position(&pcur, &mtr); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - tm = ut_clock(); - printf("Wall time for TPC-A %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ - - -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Inserts for TPC-C. */ - -ulint -test9A( -/*===*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; -/* dtuple_t* entry; - btr_pcur_t pcur; - mtr_t mtr; - dict_index_t* index; - dict_tree_t* tree; -*/ - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 9A. INSERTS FOR TPC-C\n"); - -#define TPC_C_TABLE_SIZE 15000 - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - btr_search_print_info(); - - /*-------------------------------------*/ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE4", trx); - - row = dtuple_create(heap, 12 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_test_tuple_TPC_C(row, rnd, buf); - - rnd = rnd + 1; - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - btr_validate_tree(tree); - - /* Check inserted entries */ - rnd = 0; - - entry = dtuple_create(heap, 1); - - for (i = 0; i < TPC_C_TABLE_SIZE; i++) { - - dtuple_gen_search_tuple_TPC_C(entry, rnd, buf); - - rnd = rnd + 1; - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, - &mtr); - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - btr_pcur_close(&pcur); - mtr_commit(&mtr); - } - - btr_validate_tree(tree); -#endif - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - -/* dict_table_print_by_name("TS_TABLE4"); */ - -/* mem_heap_free(heap); */ - return(0); -} - -/********************************************************************* -Test for TPC-C transaction. Test 9A must be run first to populate table. */ - -ulint -test9( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint j; - ulint i; - byte* ptr; - ulint len; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - ulint rnd = 0; - byte buf2[240]; - rec_t* rec; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 9. TPC-C %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE4", trx); - - update = upd_create(3, heap); - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table2); - ufield = upd_get_nth_field(update, 2); - - upd_field_set_col_no(ufield, 1, table2); - - entry = dtuple_create(heap, 1); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); -loop: - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IS, thr)); - ut_a(DB_SUCCESS == lock_table(0, table2, LOCK_IX, thr)); - -/* printf("Round %lu\n", count); */ - -for (j = 0; j < 13; j++) { - - /*-------------------------------------*/ - /* SELECT FROM 'ITEM' */ - - rnd += 876751; - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_S, thr); - ut_a(err == DB_SUCCESS); - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 5; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - - mtr_commit(&mtr); - - /*-------------------------------------*/ - /* UPDATE 'STOCK' */ - - rnd += 876751; - - if (count % 1231 == 0) { - dummy++; - } - - dtuple_gen_search_tuple_TPC_C(entry, rnd % TPC_C_TABLE_SIZE, buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_MODIFY_LEAF, &pcur, &mtr); - - ut_a(0 == cmp_dtuple_rec(entry, btr_pcur_get_rec(&pcur))); - -/* btr_pcur_store_position(&pcur, &mtr); */ - - rec = btr_pcur_get_rec(&pcur); - - for (i = 0; i < 10; i++) { - ptr = rec_get_nth_field(rec, i + 2, &len); - - ut_memcpy(buf2 + i * 24, ptr, len); - } - -/* btr_pcur_commit(&pcur); */ - -/* err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); */ - ut_a(DB_SUCCESS == lock_clust_rec_cons_read_check( - btr_pcur_get_rec(&pcur), - index)); -/* ut_a(err == DB_SUCCESS); */ - - ufield = upd_get_nth_field(update, 0); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 1); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - ufield = upd_get_nth_field(update, 2); - - dfield_set_data(&(ufield->new_val), "1234", 5); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - btr_pcur_close(&pcur); - /*-------------------------------------*/ - /* INSERT INTO 'ORDERLINE' */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count * 13 + j, DTUPLE_TEST_FIXED30, buf); - - ins_node_reset(inode); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -} - /*-------------------------------------*/ - /* COMMIT */ - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ - count++; - - if (count < *((ulint*)arg)) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - - tm = ut_clock(); - printf("Wall time for TPC-C %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - btr_search_index_print_info(index); - btr_search_index_print_info(dict_table_get_first_index(table)); - -/* mem_print_info(); */ - /*-------------------------------------*/ -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/********************************************************************* -Init for purge test. */ - -ulint -test10_1( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.1. PURGE INIT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 200; i++) { - - dtuple_gen_test_tuple3(row, i * 100 + thr_no, - DTUPLE_TEST_FIXED30, buf); - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 200); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_2_r( -/*=======*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - byte buf2[1000]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.2. PURGE TEST UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - update = upd_create(2, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 87607651; - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - tuple_no = i; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - upd_field_set_col_no(ufield, 0, table); - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - dfield_set_data(&(ufield->new_val), dfield_get_data( - dtuple_get_nth_field(entry, 0)), - dfield_get_len( - dtuple_get_nth_field(entry, 0))); - ufield = upd_get_nth_field(update, 1); - - upd_field_set_col_no(ufield, 1, table); - - rnd += 98326761; - - dfield_set_data(&(ufield->new_val), buf2, rnd % 2000); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - fsp_validate(0); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu updates %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - - mem_pool_print_info(mem_comm_pool); - - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - - os_thread_sleep(2000000); - - count++; - - if (count < 1) { - - goto loop; - } - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_3( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.3. PURGE TEST DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 200; i++) { - - rnd = i; - tuple_no = rnd; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - return(0); -} - -/********************************************************************* -Test for purge. */ - -ulint -test10_5( -/*=====*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* entry; - byte buf[100]; - btr_pcur_t pcur; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - del_node_t* node; - ulint err; - ulint thr_no; - ulint tuple_no; - - printf("-------------------------------------------------\n"); - printf("TEST 10.5. PURGE TEST UNCOMMITTED DELETES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - /*-------------------------------------*/ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - node = del_node_create(fork, thr, table, &pcur, heap); - thr->child = node; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - entry = dtuple_create(heap, 1); - - oldtm = ut_clock(); - - thr_no = *((ulint*)arg); - - ut_a(DB_SUCCESS == lock_table(0, table, LOCK_IX, thr)); - - for (i = 0; i < 50; i++) { - - rnd = i; - tuple_no = rnd % 100; - - dtuple_gen_search_tuple3(entry, tuple_no * 100 + 10 + thr_no, buf); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(index, entry, PAGE_CUR_LE, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - -/* printf("Thread %lu to update row %lu\n", thr_no, tuple_no); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - tm = ut_clock(); - printf("Wall time for %lu delete markings %lu milliseconds\n", - i, tm - oldtm); - -/* dict_table_print_by_name("TS_TABLE1"); */ - - printf("Validating tree\n"); - btr_validate_tree(tree); - printf("Validated\n"); - -/* lock_print_info(); */ - -/* mem_print_info(); */ - - return(0); -} - -/********************************************************************* -Multithreaded test for purge. */ - -ulint -test10mt( -/*=====*/ - void* arg) -{ - ulint i; - ulint thr_no; - - thr_no = *((ulint*)arg); - - printf("Thread %lu starts purge test\n", thr_no); - - for (i = 0; i < 2; i++) { - test10_1(arg); - - sync_print(); - - fsp_validate(0); - - test10_2_r(arg); - sync_print(); - - test10_2(arg); - sync_print(); - - lock_validate(); - - test10_3(arg); - sync_print(); - } - - printf("Thread %lu ends purge test\n", thr_no); - - return(0); -} - -/********************************************************************* -Purge test. */ - -ulint -test10_4( -/*=====*/ - void* arg) -{ - ulint i; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 10.4. PURGE TEST\n"); - - for (i = 0; i < 30; i++) { - trx_purge(); - - printf("%lu pages purged\n", purge_sys->n_pages_handled); - - os_thread_sleep(5000000); - } - -/* dict_table_print_by_name("TS_TABLE1"); */ - - return(0); -} - -/********************************************************************* -This thread is used to test insert buffer merge. */ - -ulint -test_ibuf_merge( -/*============*/ - void* arg) -{ - ulint sum_sizes; - ulint volume; - - ut_ad(arg); - - printf("Starting ibuf merge\n"); - - sum_sizes = 0; - volume = 1; - - while (volume) { - volume = ibuf_contract(FALSE); - - sum_sizes += volume; - } - - printf("Ibuf merged %lu bytes\n", sum_sizes); - - os_thread_sleep(5000000); - - return(0); -} - -/********************************************************************* -This thread is used to measure contention of latches. */ - -ulint -test_measure_cont( -/*==============*/ - void* arg) -{ - ulint i, j; - ulint count; - - ut_ad(arg); - - printf("Starting contention measurement\n"); - - for (i = 0; i < 1000; i++) { - count = 0; - - for (j = 0; j < 100; j++) { - - os_thread_sleep(10000); - - if ((&(buf_pool->mutex))->lock_word) { - - count++; - } - } - - printf("Mutex reserved %lu of %lu peeks\n", count, j); - } - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - ulint n5000 = 500; - ulint err; - - oldtm = ut_clock(); - -/* buf_debug_prints = TRUE; */ - log_do_write = TRUE; - log_debug_writes = FALSE; -/* btr_search_use_hash = FALSE; */ - - srv_boot("initfile"); - os_aio_init(576, 9, 100); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - lock_sys_create(1024); - - create_files(); - create_log_files(); - - sess_sys_init_at_db_start(); - - mem_validate(); - - /* Tests crash recovery: */ -/* - err = recv_recovery_from_checkpoint_start(LOG_CHECKPOINT, - ut_dulint_max); - ut_a(err == DB_SUCCESS); - - recv_compare_spaces_low(0, 4, 100); - - trx_sys_init_at_db_start(); - - dict_boot(); - - recv_recovery_from_checkpoint_finish(); -*/ - /* Tests archive recovery: */ - - err = recv_recovery_from_archive_start(ut_dulint_max, - "ib_arch_log_0_0000000000"); - ut_a(err == DB_SUCCESS); - - recv_compare_spaces_low(0, 4, 500); - - trx_sys_init_at_db_start(); - - dict_boot(); - - recv_recovery_from_archive_finish(); - -/* test4_2(); */ - - log_make_checkpoint_at(ut_dulint_max); - -/* dict_table_print_by_name("SYS_TABLES"); - - dict_table_print_by_name("SYS_COLUMNS"); - - dict_table_print_by_name("SYS_INDEXES"); */ - - dict_table_print_by_name("TS_TABLE1"); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/btr/ts/tss.c b/innobase/btr/ts/tss.c deleted file mode 100644 index 4af3fda4415..00000000000 --- a/innobase/btr/ts/tss.c +++ /dev/null @@ -1,397 +0,0 @@ -/************************************************************************ -Test for the server - -(c) 1996-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "os0proc.h" -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "mem0pool.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "buf0flu.h" -#include "os0file.h" -#include "os0thread.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "log0recv.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "btr0cur.h" -#include "btr0sea.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "trx0purge.h" -#include "row0ins.h" -#include "row0sel.h" -#include "row0upd.h" -#include "row0row.h" -#include "lock0lock.h" -#include "ibuf0ibuf.h" -#include "pars0pars.h" -#include "btr0sea.h" - -bool measure_cont = FALSE; - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte rnd_buf[67000]; - - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - ulint i; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - fil_aio_wait(segment); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - } - - return(0); -} - -/************************************************************************* -Creates or opens the log files. */ - -void -create_log_files(void) -/*==================*/ -{ - bool ret; - ulint i, k; - char name[20]; - - printf("--------------------------------------------------------\n"); - printf("Create or open log files\n"); - - strcpy(name, "logfile00"); - - for (k = 0; k < srv_n_log_groups; k++) { - - for (i = 0; i < srv_n_log_files; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, OS_FILE_AIO, - &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_AIO, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - 8192 * srv_log_file_size, 0)); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k + 100, FIL_LOG); - } - - ut_a(fil_validate()); - - fil_node_create(name, srv_log_file_size, k + 100); - } - - fil_space_create(name, k + 200, FIL_LOG); - - log_group_init(k, srv_n_log_files, - srv_log_file_size * UNIV_PAGE_SIZE, - k + 100, k + 200); - } -} - -/************************************************************************* -Creates the files for the file system test and inserts them to the file -system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[10]; - os_thread_id_t id[10]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < 2 * srv_n_spaces; k += 2) { - for (i = 0; i < srv_n_files; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_NORMAL, &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_NORMAL, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - UNIV_PAGE_SIZE * srv_file_size, 0)); - /* Initialize the file contents to a random value */ - /* - for (j = 0; j < srv_file_size; j++) { - - for (c = 0; c < UNIV_PAGE_SIZE; c++) { - - rnd_buf[c] = 0xFF; - } - - os_file_write(files[i], rnd_buf, - UNIV_PAGE_SIZE * j, 0, - UNIV_PAGE_SIZE); - } - */ - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, FIL_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, srv_file_size, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - mutex_set_level(&ios_mutex, SYNC_NO_ORDER_CHECK); - - /* Create i/o-handler threads: */ - - for (i = 0; i < 9; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space header of space. */ - -void -init_spaces(void) -/*=============*/ -{ - mtr_t mtr; - - mtr_start(&mtr); - - fsp_header_init(0, srv_file_size * srv_n_files, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -This thread is used to measure contention of latches. */ - -ulint -test_measure_cont( -/*==============*/ - void* arg) -{ - ulint i, j, k; - ulint count[8]; - ulint lcount[8]; - ulint lscount; - ulint lkcount; - ulint pcount, kcount, scount; - - UT_NOT_USED(arg); - - printf("Starting contention measurement\n"); - - for (i = 0; i < 1000; i++) { - - for (k = 0; k < 8; k++) { - count[k] = 0; - lcount[k] = 0; - } - - pcount = 0; - kcount = 0; - scount = 0; - lscount = 0; - lkcount = 0; - - for (j = 0; j < 100; j++) { - - if (srv_measure_by_spin) { - ut_delay(ut_rnd_interval(0, 20000)); - } else { - os_thread_sleep(20000); - } - - if (kernel_mutex.lock_word) { - kcount++; - } - - if (lock_kernel_reserved) { - lkcount++; - } - - if (buf_pool->mutex.lock_word) { - pcount++; - } - - if (btr_search_mutex.lock_word) { - scount++; - } - - for (k = 0; k < 8; k++) { - - if (btr_search_sys-> - hash_index->mutexes[k].lock_word) { - - count[k]++; - } - } - - for (k = 0; k < 2; k++) { - - if (lock_sys->rec_hash->mutexes[k].lock_word) { - - lcount[k]++; - } - } - - if (kernel_mutex.lock_word - || lock_sys->rec_hash->mutexes[0].lock_word - || lock_sys->rec_hash->mutexes[1].lock_word) { - - lscount++; - } - } - - printf( -"Mutex res. p %lu, k %lu %lu, %lu %lu %lu s %lu, %lu %lu %lu %lu %lu %lu %lu %lu of %lu\n", - pcount, kcount, lkcount, lcount[0], lcount[1], lscount, scount, - count[0], count[1], count[2], count[3], - count[4], count[5], count[6], count[7], j); - - sync_print_wait_info(); - - printf("N log i/os %lu, n non sea %lu, n sea succ %lu\n", - log_sys->n_log_ios, btr_cur_n_non_sea, - btr_search_n_succ); - } - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - os_thread_id_t thread_id; - - log_do_write = TRUE; -/* yydebug = TRUE; */ - - srv_boot("srv_init"); - - os_aio_init(576, 9, 100); - - fil_init(25); - - buf_pool_init(srv_pool_size, srv_pool_size); - - fsp_init(); - log_init(); - - lock_sys_create(srv_lock_table_size); - - create_files(); - create_log_files(); - - init_spaces(); - - sess_sys_init_at_db_start(); - - trx_sys_create(); - - dict_create(); - - log_make_checkpoint_at(ut_dulint_max); - - if (srv_measure_contention) { - os_thread_create(&test_measure_cont, NULL, &thread_id); - } - - if (!srv_log_archive_on) { - - ut_a(DB_SUCCESS == log_archive_noarchivelog()); - } - - srv_master_thread(); - - printf("TESTS COMPLETED SUCCESSFULLY!\n"); - - os_process_exit(0); -} diff --git a/innobase/btr/ts/tssrv.c b/innobase/btr/ts/tssrv.c deleted file mode 100644 index 78d247968d5..00000000000 --- a/innobase/btr/ts/tssrv.c +++ /dev/null @@ -1,535 +0,0 @@ -/************************************************************************ -Test for the server - -(c) 1996-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "os0proc.h" -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "mem0pool.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "buf0flu.h" -#include "os0file.h" -#include "os0thread.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "log0recv.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "btr0cur.h" -#include "btr0sea.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "trx0purge.h" -#include "row0ins.h" -#include "row0sel.h" -#include "row0upd.h" -#include "row0row.h" -#include "lock0lock.h" -#include "ibuf0ibuf.h" -#include "pars0pars.h" -#include "btr0sea.h" - -bool measure_cont = FALSE; - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte rnd_buf[67000]; - -ulint glob_var1 = 0; -ulint glob_var2 = 0; - -mutex_t mutex2; - -mutex_t test_mutex1; -mutex_t test_mutex2; - -mutex_t* volatile mutexes; - -bool always_false = FALSE; - -ulint* test_array; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - ulint i; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - fil_aio_wait(segment); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - } - - return(0); -} - -/************************************************************************* -Creates or opens the log files. */ - -void -create_log_files(void) -/*==================*/ -{ - bool ret; - ulint i, k; - char name[20]; - - printf("--------------------------------------------------------\n"); - printf("Create or open log files\n"); - - strcpy(name, "logfile00"); - - for (k = 0; k < srv_n_log_groups; k++) { - - for (i = 0; i < srv_n_log_files; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, OS_FILE_AIO, - &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_AIO, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - 8192 * srv_log_file_size, 0)); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k + 100, FIL_LOG); - } - - ut_a(fil_validate()); - - fil_node_create(name, srv_log_file_size, k + 100); - } - - fil_space_create(name, k + 200, FIL_LOG); - - log_group_init(k, srv_n_log_files, - srv_log_file_size * UNIV_PAGE_SIZE, - k + 100, k + 200); - } -} - -/************************************************************************* -Creates the files for the file system test and inserts them to the file -system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[10]; - os_thread_id_t id[10]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < 2 * srv_n_spaces; k += 2) { - for (i = 0; i < srv_n_files; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_NORMAL, &ret); - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, OS_FILE_NORMAL, &ret); - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], - UNIV_PAGE_SIZE * srv_file_size, 0)); - /* Initialize the file contents to a random value */ - /* - for (j = 0; j < srv_file_size; j++) { - - for (c = 0; c < UNIV_PAGE_SIZE; c++) { - - rnd_buf[c] = 0xFF; - } - - os_file_write(files[i], rnd_buf, - UNIV_PAGE_SIZE * j, 0, - UNIV_PAGE_SIZE); - } - */ - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, FIL_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, srv_file_size, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - mutex_set_level(&ios_mutex, SYNC_NO_ORDER_CHECK); - - /* Create i/o-handler threads: */ - - for (i = 0; i < 9; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space header of space. */ - -void -init_spaces(void) -/*=============*/ -{ - mtr_t mtr; - - mtr_start(&mtr); - - fsp_header_init(0, srv_file_size * srv_n_files, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -This thread is used to measure contention of latches. */ - -ulint -test_measure_cont( -/*==============*/ - void* arg) -{ - ulint i, j; - ulint pcount, kcount, s_scount, s_xcount, s_mcount, lcount; - ulint t1count; - ulint t2count; - - UT_NOT_USED(arg); - - printf("Starting contention measurement\n"); - - for (i = 0; i < 1000; i++) { - - pcount = 0; - kcount = 0; - s_scount = 0; - s_xcount = 0; - s_mcount = 0; - lcount = 0; - t1count = 0; - t2count = 0; - - for (j = 0; j < 100; j++) { - - if (srv_measure_by_spin) { - ut_delay(ut_rnd_interval(0, 20000)); - } else { - os_thread_sleep(20000); - } - - if (kernel_mutex.lock_word) { - kcount++; - } - - if (buf_pool->mutex.lock_word) { - pcount++; - } - - if (log_sys->mutex.lock_word) { - lcount++; - } - - if (btr_search_latch.reader_count) { - s_scount++; - } - - if (btr_search_latch.writer != RW_LOCK_NOT_LOCKED) { - s_xcount++; - } - - if (btr_search_latch.mutex.lock_word) { - s_mcount++; - } - - if (test_mutex1.lock_word) { - t1count++; - } - - if (test_mutex2.lock_word) { - t2count++; - } - } - - printf( - "Mutex res. l %lu, p %lu, k %lu s x %lu s s %lu s mut %lu of %lu\n", - lcount, pcount, kcount, s_xcount, s_scount, s_mcount, j); - - sync_print_wait_info(); - - printf( - "log i/o %lu n non sea %lu n succ %lu n h fail %lu\n", - log_sys->n_log_ios, btr_cur_n_non_sea, - btr_search_n_succ, btr_search_n_hash_fail); - } - - return(0); -} - -/********************************************************************* -This thread is used to test contention of latches. */ - -ulint -test_sync( -/*======*/ - void* arg) -{ - ulint tm, oldtm; - ulint i, j; - ulint sum; - ulint rnd = ut_rnd_gen_ulint(); - ulint mut_ind; - byte* ptr; - - UT_NOT_USED(arg); - - printf("Starting mutex reservation test\n"); - - oldtm = ut_clock(); - - sum = 0; - rnd = 87354941; - - for (i = 0; i < srv_test_n_loops; i++) { - - for (j = 0; j < srv_test_n_free_rnds; j++) { - rnd += 423087123; - - sum += test_array[rnd % (256 * srv_test_array_size)]; - } - - rnd += 43605677; - - mut_ind = rnd % srv_test_n_mutexes; - - mutex_enter(mutexes + mut_ind); - - for (j = 0; j < srv_test_n_reserved_rnds; j++) { - rnd += 423087121; - - sum += test_array[rnd % (256 * srv_test_array_size)]; - } - - mutex_exit(mutexes + mut_ind); - - if (srv_test_cache_evict) { - ptr = (byte*)(mutexes + mut_ind); - - for (j = 0; j < 4; j++) { - ptr += 256 * 1024; - sum += *((ulint*)ptr); - } - } - } - - if (always_false) { - printf("%lu", sum); - } - - tm = ut_clock(); - - printf("Wall time for res. test %lu milliseconds\n", tm - oldtm); - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - os_thread_id_t thread_ids[1000]; - ulint tm, oldtm; - ulint rnd; - ulint i, sum; - byte* ptr; -/* mutex_t mutex; */ - - log_do_write = TRUE; -/* yydebug = TRUE; */ - - srv_boot("srv_init"); - - os_aio_init(576, 9, 100); - - fil_init(25); - - buf_pool_init(srv_pool_size, srv_pool_size); - - fsp_init(); - log_init(); - - lock_sys_create(srv_lock_table_size); - - create_files(); - create_log_files(); - - init_spaces(); - - sess_sys_init_at_db_start(); - - trx_sys_create(); - - dict_create(); - - log_make_checkpoint_at(ut_dulint_max); - - printf("Hotspot semaphore addresses k %lx, p %lx, l %lx, s %lx\n", - &kernel_mutex, &(buf_pool->mutex), - &(log_sys->mutex), &btr_search_latch); - - if (srv_measure_contention) { - os_thread_create(&test_measure_cont, NULL, thread_ids + 999); - } - - if (!srv_log_archive_on) { - - ut_a(DB_SUCCESS == log_archive_noarchivelog()); - } - -/* - mutex_create(&mutex); - - oldtm = ut_clock(); - - for (i = 0; i < 2000000; i++) { - - mutex_enter(&mutex); - - mutex_exit(&mutex); - } - - tm = ut_clock(); - - printf("Wall clock time for %lu mutex enter %lu milliseconds\n", - i, tm - oldtm); -*/ - if (srv_test_sync) { - if (srv_test_nocache) { - mutexes = os_mem_alloc_nocache(srv_test_n_mutexes - * sizeof(mutex_t)); - } else { - mutexes = mem_alloc(srv_test_n_mutexes - * sizeof(mutex_t)); - } - - sum = 0; - - rnd = 492314896; - - oldtm = ut_clock(); - - for (i = 0; i < 4000000; i++) { - - rnd += 85967944; - - ptr = ((byte*)(mutexes)) + (rnd % (srv_test_n_mutexes - * sizeof(mutex_t))); - sum += *((ulint*)ptr); - } - - tm = ut_clock(); - - printf( - "Wall clock time for %lu random access %lu milliseconds\n", - i, tm - oldtm); - if (always_false) { - printf("%lu", sum); - } - - test_array = mem_alloc(4 * 256 * srv_test_array_size); - - for (i = 0; i < srv_test_n_mutexes; i++) { - - mutex_create(mutexes + i); - } - - for (i = 0; i < srv_test_n_threads; i++) { - os_thread_create(&test_sync, NULL, thread_ids + i); - } - } - - srv_master_thread(NULL); - - printf("TESTS COMPLETED SUCCESSFULLY!\n"); - - os_process_exit(0); -} diff --git a/innobase/buf/buf0buf.c b/innobase/buf/buf0buf.c index cbf12c9e55d..c60132896ef 100644 --- a/innobase/buf/buf0buf.c +++ b/innobase/buf/buf0buf.c @@ -1106,13 +1106,13 @@ loop: buf_read_page(space, offset); - #ifdef UNIV_DEBUG +#ifdef UNIV_DEBUG buf_dbg_counter++; if (buf_dbg_counter % 37 == 0) { ut_ad(buf_validate()); } - #endif +#endif goto loop; } diff --git a/innobase/buf/ts/makefile b/innobase/buf/ts/makefile deleted file mode 100644 index 5886d06d7fa..00000000000 --- a/innobase/buf/ts/makefile +++ /dev/null @@ -1,20 +0,0 @@ - - - -include ..\..\makefile.i - -doall: tsbuf - -tsbuf: ..\buf.lib tsbuf.c - $(CCOM) $(CFL) -I.. -I..\.. ..\buf.lib ..\..\btr.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsbuf.c $(LFL) - -tsos: ..\buf.lib tsos.c - $(CCOM) $(CFL) -I.. -I..\.. ..\buf.lib ..\..\mach.lib ..\..\fil.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsos.c $(LFL) - - - - - - - - diff --git a/innobase/buf/ts/tsbuf.c b/innobase/buf/ts/tsbuf.c deleted file mode 100644 index fd6ae69653f..00000000000 --- a/innobase/buf/ts/tsbuf.c +++ /dev/null @@ -1,885 +0,0 @@ -/************************************************************************ -The test module for the file system and buffer manager - -(c) 1995 Innobase Oy - -Created 11/16/1995 Heikki Tuuri -*************************************************************************/ - -#include "string.h" - -#include "os0thread.h" -#include "os0file.h" -#include "ut0ut.h" -#include "ut0byte.h" -#include "sync0sync.h" -#include "mem0mem.h" -#include "fil0fil.h" -#include "mtr0mtr.h" -#include "mtr0log.h" -#include "log0log.h" -#include "mach0data.h" -#include "..\buf0buf.h" -#include "..\buf0flu.h" -#include "..\buf0lru.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -#define N_SPACES 1 -#define N_FILES 1 -#define FILE_SIZE 4000 -#define POOL_SIZE 1000 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - - -ulint zero = 0; - -buf_frame_t* bl_arr[POOL_SIZE]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -This thread reports the status of sync system. */ - -ulint -info_thread( -/*========*/ - void* arg) -{ - ulint segment; - - segment = *((ulint*)arg); - - for (;;) { - sync_print(); - os_aio_print(); - printf("Debug stop threads == %lu\n", ut_dbg_stop_threads); - os_thread_sleep(30000000); - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - ulint err; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[9] = (char)((ulint)'0' + k); - name[10] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - err = os_file_get_last_error(); - if (err != OS_FILE_ALREADY_EXISTS) { - printf("OS error %lu in file creation\n", err); - ut_error; - } - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -/* - n[9] = 9; - os_thread_create(info_thread, n + 9, id); -*/ -} - -/************************************************************************ -Creates the test database files. */ - -void -create_db(void) -/*===========*/ -{ - ulint i; - byte* frame; - ulint j; - ulint tm, oldtm; - mtr_t mtr; - - printf("--------------------------------------------------------\n"); - printf("Write database pages\n"); - - oldtm = ut_clock(); - - for (i = 0; i < N_SPACES; i++) { - for (j = 0; j < FILE_SIZE * N_FILES; j++) { - mtr_start(&mtr); - mtr_set_log_mode(&mtr, MTR_LOG_NONE); - - frame = buf_page_create(i, j, &mtr); - buf_page_get(i, j, RW_X_LATCH, &mtr); - - if (j > FILE_SIZE * N_FILES - 64 * 2 - 1) { - mlog_write_ulint(frame + FIL_PAGE_PREV, j - 5, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + FIL_PAGE_NEXT, j - 7, - MLOG_4BYTES, &mtr); - } else { - mlog_write_ulint(frame + FIL_PAGE_PREV, j - 1, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + FIL_PAGE_NEXT, j + 1, - MLOG_4BYTES, &mtr); - } - - mlog_write_ulint(frame + FIL_PAGE_OFFSET, j, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + FIL_PAGE_SPACE, i, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + COUNTER_OFFSET, 0, - MLOG_4BYTES, &mtr); - - mtr_commit(&mtr); - } - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - printf("--------------------------------------------------------\n"); - printf("TEST 1 A. Test of page creation when page resides in buffer\n"); - for (i = 0; i < N_SPACES; i++) { - for (j = FILE_SIZE * N_FILES - 200; - j < FILE_SIZE * N_FILES; j++) { - mtr_start(&mtr); - mtr_set_log_mode(&mtr, MTR_LOG_NONE); - - frame = buf_page_create(i, j, &mtr); - buf_page_get(i, j, RW_X_LATCH, &mtr); - - mlog_write_ulint(frame + FIL_PAGE_PREV, - j - 1, MLOG_4BYTES, &mtr); - - mlog_write_ulint(frame + FIL_PAGE_NEXT, - j + 1, MLOG_4BYTES, &mtr); - - mlog_write_ulint(frame + FIL_PAGE_OFFSET, j, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + FIL_PAGE_SPACE, i, - MLOG_4BYTES, &mtr); - mtr_commit(&mtr); - } - } - - printf("--------------------------------------------------------\n"); - printf("TEST 1 B. Flush pages\n"); - - buf_flush_batch(BUF_FLUSH_LIST, POOL_SIZE / 2); - buf_validate(); - - printf("--------------------------------------------------------\n"); - printf("TEST 1 C. Allocate POOL_SIZE blocks to flush pages\n"); - - buf_validate(); - /* Flush the pool of dirty pages */ - for (i = 0; i < POOL_SIZE; i++) { - - bl_arr[i] = buf_frame_alloc(); - } - buf_validate(); - buf_LRU_print(); - - for (i = 0; i < POOL_SIZE; i++) { - - buf_frame_free(bl_arr[i]); - } - - buf_validate(); - ut_a(buf_all_freed()); - - mtr_start(&mtr); - frame = buf_page_get(0, 313, RW_S_LATCH, &mtr); -#ifdef UNIV_ASYNC_IO - ut_a(buf_page_io_query(buf_block_align(frame)) == TRUE); -#endif - mtr_commit(&mtr); -} - -/************************************************************************ -Reads the test database files. */ - -void -test1(void) -/*=======*/ -{ - ulint i, j, k, c; - byte* frame; - ulint tm, oldtm; - mtr_t mtr; - - printf("--------------------------------------------------------\n"); - printf("TEST 1 D. Read linearly database files\n"); - - oldtm = ut_clock(); - - for (k = 0; k < 1; k++) { - for (i = 0; i < N_SPACES; i++) { - for (j = 0; j < N_FILES * FILE_SIZE; j++) { - mtr_start(&mtr); - - frame = buf_page_get(i, j, RW_S_LATCH, &mtr); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr) - == j); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr) - == i); - - mtr_commit(&mtr); - } - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu pages %lu milliseconds\n", - k * i * j, tm - oldtm); - buf_validate(); - - printf("--------------------------------------------------------\n"); - printf("TEST 1 E. Read linearly downward database files\n"); - - oldtm = ut_clock(); - - c = 0; - - for (k = 0; k < 1; k++) { - for (i = 0; i < N_SPACES; i++) { - for (j = ut_min(1000, FILE_SIZE - 1); j > 0; j--) { - mtr_start(&mtr); - - frame = buf_page_get(i, j, RW_S_LATCH, &mtr); - c++; - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr) - == j); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr) - == i); - - - ut_a(buf_page_io_query(buf_block_align(frame)) - == FALSE); - - mtr_commit(&mtr); - } - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu pages %lu milliseconds\n", - c, tm - oldtm); - buf_validate(); -} - -/************************************************************************ -Reads the test database files. */ - -void -test2(void) -/*=======*/ -{ - ulint i, j, k; - byte* frame; - ulint tm, oldtm; - mtr_t mtr; - - printf("--------------------------------------------------------\n"); - printf("TEST 2. Read randomly database files\n"); - - oldtm = ut_clock(); - - for (k = 0; k < 100; k++) { - i = ut_rnd_gen_ulint() % N_SPACES; - j = ut_rnd_gen_ulint() % (N_FILES * FILE_SIZE); - - mtr_start(&mtr); - - frame = buf_page_get(i, j, RW_S_LATCH, &mtr); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr) - == j); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr) - == i); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall clock time for random %lu read %lu milliseconds\n", - k, tm - oldtm); -} - -/************************************************************************ -Reads the test database files. */ - -void -test3(void) -/*=======*/ -{ - ulint i, j, k; - byte* frame; - ulint tm, oldtm; - ulint rnd; - mtr_t mtr; - - if (FILE_SIZE < POOL_SIZE + 3050 + ut_dbg_zero) { - return; - } - - printf("Flush the pool of high-offset pages\n"); - - /* Flush the pool of high-offset pages */ - for (i = 0; i < POOL_SIZE; i++) { - - mtr_start(&mtr); - - frame = buf_page_get(0, i, RW_S_LATCH, &mtr); - - mtr_commit(&mtr); - } - buf_validate(); - - printf("--------------------------------------------------------\n"); - printf("TEST 3. Read randomly database pages, no read-ahead\n"); - - oldtm = ut_clock(); - - rnd = 123; - - for (k = 0; k < 400; k++) { - rnd += 23477; - - i = 0; - j = POOL_SIZE + 10 + rnd % 3000; - - mtr_start(&mtr); - - frame = buf_page_get(i, j, RW_S_LATCH, &mtr); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr) - == j); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr) - == i); - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall clock time for %lu random no read-ahead %lu milliseconds\n", - k, tm - oldtm); - - buf_validate(); - printf("Flush the pool of high-offset pages\n"); - /* Flush the pool of high-offset pages */ - for (i = 0; i < POOL_SIZE; i++) { - - mtr_start(&mtr); - - frame = buf_page_get(0, i, RW_S_LATCH, &mtr); - - mtr_commit(&mtr); - } - - buf_validate(); - printf("--------------------------------------------------------\n"); - printf("TEST 3 B. Read randomly database pages, random read-ahead\n"); - - oldtm = ut_clock(); - - rnd = 123; - for (k = 0; k < 400; k++) { - rnd += 23477; - - i = 0; - j = POOL_SIZE + 10 + rnd % 400; - - mtr_start(&mtr); - - frame = buf_page_get(i, j, RW_S_LATCH, &mtr); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr) - == j); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr) - == i); - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall clock time for %lu random read-ahead %lu milliseconds\n", - k, tm - oldtm); -} - -/************************************************************************ -Tests speed of CPU algorithms. */ - -void -test4(void) -/*=======*/ -{ - ulint i, j; - ulint tm, oldtm; - mtr_t mtr; - buf_frame_t* frame; - - os_thread_sleep(2000000); - - printf("--------------------------------------------------------\n"); - printf("TEST 4. Speed of CPU algorithms\n"); - - oldtm = ut_clock(); - - for (j = 0; j < 1000; j++) { - - mtr_start(&mtr); - for (i = 0; i < 20; i++) { - - frame = buf_page_get(0, i, RW_S_LATCH, &mtr); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall clock time for %lu page get-release %lu milliseconds\n", - i * j, tm - oldtm); - - buf_validate(); - - oldtm = ut_clock(); - - for (i = 0; i < 10000; i++) { - frame = buf_frame_alloc(); - buf_frame_free(frame); - } - - tm = ut_clock(); - printf("Wall clock time for %lu block alloc-free %lu milliseconds\n", - i, tm - oldtm); - - ha_print_info(buf_pool->page_hash); - buf_print(); -} - -/************************************************************************ -Tests various points of code. */ - -void -test5(void) -/*=======*/ -{ - buf_frame_t* frame; - fil_addr_t addr; - ulint space; - mtr_t mtr; - - printf("--------------------------------------------------------\n"); - printf("TEST 5. Various tests \n"); - - mtr_start(&mtr); - - frame = buf_page_get(0, 313, RW_S_LATCH, &mtr); - - ut_a(buf_frame_get_space_id(frame) == 0); - ut_a(buf_frame_get_page_no(frame) == 313); - - ut_a(buf_frame_align(frame + UNIV_PAGE_SIZE - 1) == frame); - ut_a(buf_frame_align(frame) == frame); - - ut_a(buf_block_align(frame + UNIV_PAGE_SIZE - 1) == - buf_block_align(frame)); - - buf_ptr_get_fsp_addr(frame + UNIV_PAGE_SIZE - 1, &space, &addr); - - ut_a(addr.page == 313) - ut_a(addr.boffset == UNIV_PAGE_SIZE - 1); - ut_a(space == 0); - - mtr_commit(&mtr); -} - -/************************************************************************ -Random test thread function. */ - -ulint -random_thread( -/*===========*/ - void* arg) -{ - ulint n; - ulint i, j, r, t, p, sp, count; - ulint s; - buf_frame_t* arr[POOL_SIZE / N_THREADS]; - buf_frame_t* frame; - mtr_t mtr; - mtr_t mtr2; - - n = *((ulint*)arg); - - printf("Random test thread %lu starts\n", os_thread_get_curr_id()); - - for (i = 0; i < 30; i++) { - t = ut_rnd_gen_ulint() % 10; - r = ut_rnd_gen_ulint() % 100; - s = ut_rnd_gen_ulint() % (POOL_SIZE / N_THREADS); - p = ut_rnd_gen_ulint(); - sp = ut_rnd_gen_ulint() % N_SPACES; - - if (i % 100 == 0) { - printf("Thr %lu tst %lu starts\n", os_thread_get_curr_id(), t); - } - ut_a(buf_validate()); - - mtr_start(&mtr); - if (t == 6) { - /* Allocate free blocks */ - for (j = 0; j < s; j++) { - arr[j] = buf_frame_alloc(); - ut_a(arr[j]); - } - for (j = 0; j < s; j++) { - buf_frame_free(arr[j]); - } - } else if (t == 9) { -/* buf_flush_batch(BUF_FLUSH_LIST, 30); */ - - } else if (t == 7) { - /* x-lock many blocks */ - for (j = 0; j < s; j++) { - arr[j] = buf_page_get(sp, (p + j) - % (N_FILES * FILE_SIZE), - RW_X_LATCH, - &mtr); - ut_a(arr[j]); - if (j > 0) { - ut_a(arr[j] != arr[j - 1]); - } - } - ut_a(buf_validate()); - } else if (t == 8) { - /* s-lock many blocks */ - for (j = 0; j < s; j++) { - arr[j] = buf_page_get(sp, (p + j) - % (N_FILES * FILE_SIZE), - RW_S_LATCH, - &mtr); - ut_a(arr[j]); - if (j > 0) { - ut_a(arr[j] != arr[j - 1]); - } - } - } else if (t <= 2) { - for (j = 0; j < r; j++) { - /* Read pages */ - mtr_start(&mtr2); - frame = buf_page_get(sp, - p % (N_FILES * FILE_SIZE), - RW_S_LATCH, &mtr2); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr2) - == p % (N_FILES * FILE_SIZE)); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr2) - == sp); - mtr_commit(&mtr2); - if (t == 0) { - p++; /* upward */ - } else if (t == 1) { - p--; /* downward */ - } else if (t == 2) { - p = ut_rnd_gen_ulint(); /* randomly */ - } - } - } else if (t <= 5) { - for (j = 0; j < r; j++) { - /* Write pages */ - mtr_start(&mtr2); - frame = buf_page_get(sp, p % (N_FILES * FILE_SIZE), - RW_X_LATCH, &mtr2); - count = 1 + mtr_read_ulint(frame + COUNTER_OFFSET, - MLOG_4BYTES, &mtr2); - mutex_enter(&incs_mutex); - incs++; - mutex_exit(&incs_mutex); - mlog_write_ulint(frame + COUNTER_OFFSET, count, - MLOG_4BYTES, &mtr2); - mtr_commit(&mtr2); - if (t == 3) { - p++; /* upward */ - } else if (t == 4) { - p--; /* downward */ - } else if (t == 5) { - p = ut_rnd_gen_ulint(); /* randomly */ - } - } - } /* if t = */ - - mtr_commit(&mtr); -/* printf("Thr %lu tst %lu ends ", os_thread_get_curr_id(), t); */ - ut_a(buf_validate()); - } /* for i */ - printf("\nRandom test thread %lu exits\n", os_thread_get_curr_id()); - return(0); -} - -/************************************************************************ -Random test thread function which reports the rw-lock list. */ - -ulint -rw_list_thread( -/*===========*/ - void* arg) -{ - ulint n; - ulint i; - - n = *((ulint*)arg); - - printf("\nRw list test thread %lu starts\n", os_thread_get_curr_id()); - - for (i = 0; i < 10; i++) { - os_thread_sleep(3000000); - rw_lock_list_print_info(); - buf_validate(); - } - - return(0); -} - -/************************************************************************* -Performs random operations on the buffer with several threads. */ - -void -test6(void) -/*=======*/ -{ - ulint i, j; - os_thread_t thr[N_THREADS + 1]; - os_thread_id_t id[N_THREADS + 1]; - ulint n[N_THREADS + 1]; - ulint count = 0; - buf_frame_t* frame; - mtr_t mtr; - - printf("--------------------------------------------------------\n"); - printf("TEST 6. Random multi-thread test on the buffer \n"); - - incs = 0; - mutex_create(&incs_mutex); - - for (i = 0; i < N_THREADS; i++) { - n[i] = i; - - thr[i] = os_thread_create(random_thread, n + i, id + i); - } -/* - n[N_THREADS] = N_THREADS; - - thr[N_THREADS] = os_thread_create(rw_list_thread, n + N_THREADS, - id + N_THREADS); -*/ - for (i = 0; i < N_THREADS; i++) { - os_thread_wait(thr[i]); - } - -/* os_thread_wait(thr[N_THREADS]); */ - - for (i = 0; i < N_SPACES; i++) { - for (j = 0; j < N_FILES * FILE_SIZE; j++) { - mtr_start(&mtr); - - frame = buf_page_get(i, j, RW_S_LATCH, &mtr); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr) - == j); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr) - == i); - - count += mtr_read_ulint(frame + COUNTER_OFFSET, - MLOG_4BYTES, &mtr); - - mtr_commit(&mtr); - } - } - - printf("Count %lu incs %lu\n", count, incs); - ut_a(count == incs); -} - -/************************************************************************ -Frees the spaces in the file system. */ - -void -free_system(void) -/*=============*/ -{ - ulint i; - - for (i = 0; i < N_SPACES; i++) { - fil_space_free(i); - } -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - -/* buf_debug_prints = TRUE; */ - - oldtm = ut_clock(); - - os_aio_init(160, 5); - sync_init(); - mem_init(1500000); - fil_init(26); /* Allow 25 open files at a time */ - buf_pool_init(POOL_SIZE, POOL_SIZE); - log_init(); - - buf_validate(); - - ut_a(fil_validate()); - - create_files(); - - create_db(); - - buf_validate(); - - test1(); - buf_validate(); - - test2(); - buf_validate(); - - test3(); - buf_validate(); - - test4(); - - test5(); - - buf_validate(); - - test6(); - - buf_validate(); - - buf_print(); - - buf_flush_batch(BUF_FLUSH_LIST, POOL_SIZE + 1); - buf_print(); - buf_validate(); - - os_thread_sleep(1000000); - - buf_print(); - buf_all_freed(); - - free_system(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/buf/ts/tsos.c b/innobase/buf/ts/tsos.c deleted file mode 100644 index c1cc3f27172..00000000000 --- a/innobase/buf/ts/tsos.c +++ /dev/null @@ -1,185 +0,0 @@ -/************************************************************************ -The test module for the operating system interface - -(c) 1995 Innobase Oy - -Created 9/27/1995 Heikki Tuuri -*************************************************************************/ - - -#include "../os0thread.h" -#include "../os0shm.h" -#include "../os0proc.h" -#include "../os0sync.h" -#include "../os0file.h" -#include "ut0ut.h" -#include "sync0sync.h" -#include "mem0mem.h" - -ulint last_thr = 1; - -byte global_buf[1000000]; - -os_file_t file; -os_file_t file2; - -os_event_t gl_ready; - -mutex_t ios_mutex; -ulint ios; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = os_aio_wait(segment, &mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - ut_a(ret); -/* printf("Message for thread %lu %lu\n", segment, - (ulint)mess); */ - if ((ulint)mess == 3333) { - os_event_set(gl_ready); - } - } - - return(0); -} - -/************************************************************************ -Test of io-handler threads */ - -void -test4(void) -/*=======*/ -{ - ulint i; - bool ret; - void* buf; - ulint rnd; - ulint tm, oldtm; - - os_thread_t thr[5]; - os_thread_id_t id[5]; - ulint n[5]; - - printf("-------------------------------------------\n"); - printf("OS-TEST 4. Test of asynchronous file io\n"); - - /* Align the buffer for file io */ - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - gl_ready = os_event_create(NULL); - ios = 0; - - sync_init(); - mem_init(); - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 4096; i++) { - ret = os_aio_read(file, (byte*)buf + 8192 * (rnd % 100), - 8192 * (rnd % 4096), 0, - 8192, (void*)i); - ut_a(ret); - rnd += 1; - } - - ret = os_aio_read(file, buf, 8192 * (rnd % 1024), 0, 8192, - (void*)3333); - ut_a(ret); - - ut_a(!os_aio_all_slots_free()); - - tm = ut_clock(); - - printf("All ios queued! N ios: %lu\n", ios); - - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - os_event_wait(gl_ready); - - tm = ut_clock(); - printf("N ios: %lu\n", ios); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - os_thread_sleep(2000000); - - printf("N ios: %lu\n", ios); - - ut_a(os_aio_all_slots_free()); -} - -/************************************************************************* -Initializes the asyncronous io system for tests. */ - -void -init_aio(void) -/*==========*/ -{ - bool ret; - void* buf; - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - os_aio_init(160, 5); - file = os_file_create("j:\\tsfile4", OS_FILE_CREATE, OS_FILE_TABLESPACE, - &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == OS_FILE_ALREADY_EXISTS); - - file = os_file_create("j:\\tsfile4", OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - oldtm = ut_clock(); - - init_aio(); - - test4(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/com/ts/makefile b/innobase/com/ts/makefile deleted file mode 100644 index 01c14737c78..00000000000 --- a/innobase/com/ts/makefile +++ /dev/null @@ -1,19 +0,0 @@ - - - -include ..\..\makefile.i - -doall: tscom tscli - -tscom: ..\com.lib tscom.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\com.lib ..\..\ut.lib ..\..\mem.lib ..\..\sync.lib ..\..\os.lib tscom.c $(LFL) - -tscli: ..\com.lib tscli.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\com.lib ..\..\ut.lib ..\..\mem.lib ..\..\sync.lib ..\..\os.lib tscli.c $(LFL) - - - - - - - diff --git a/innobase/com/ts/tscli.c b/innobase/com/ts/tscli.c deleted file mode 100644 index 27a787a0e5c..00000000000 --- a/innobase/com/ts/tscli.c +++ /dev/null @@ -1,96 +0,0 @@ -/************************************************************************ -The test module for communication - -(c) 1995 Innobase Oy - -Created 9/26/1995 Heikki Tuuri -*************************************************************************/ - -#include "../com0com.h" -#include "../com0shm.h" -#include "ut0ut.h" -#include "mem0mem.h" -#include "os0thread.h" -#include "sync0ipm.h" -#include "sync0sync.h" - -byte buf[10000]; -char addr[150]; - -void -test1(void) -/*=======*/ -{ - com_endpoint_t* ep; - ulint ret; - ulint size; - ulint len; - ulint addr_len; - ulint i; - - ep = com_endpoint_create(COM_SHM); - - ut_a(ep); - - size = 8192; - - ret = com_endpoint_set_option(ep, COM_OPT_MAX_DGRAM_SIZE, - (byte*)&size, 0); - - ut_a(ret == 0); - - ret = com_bind(ep, "CLI", 3); - - ut_a(ret == 0); - - printf("Client endpoint created!\n"); - - for (i = 0; i < 10000; i++) { - - ret = com_sendto(ep, (byte*)"Hello from client!\n", 18, "SRV", 3); - - ut_a(ret == 0); - - ret = com_recvfrom(ep, buf, 10000, &len, addr, 150, &addr_len); - - ut_a(ret == 0); - - buf[len] = '\0'; - addr[addr_len] = '\0'; -/* - printf( - "Message of len %lu\n%s \nreceived from address %s of len %lu\n", - len, buf, addr, addr_len); -*/ - } - - ret = com_endpoint_free(ep); - - ut_ad(ret == 0); - - - printf("Count of extra system calls in com_shm %lu\n", - com_shm_system_call_count); - printf("Count of extra system calls in ip_mutex %lu\n", - ip_mutex_system_call_count); -} - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - sync_init(); - mem_init(); - - oldtm = ut_clock(); - - test1(); - - ut_ad(mem_all_freed()); - - tm = ut_clock(); - printf("Wall clock time for test %ld milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/com/ts/tscom.c b/innobase/com/ts/tscom.c deleted file mode 100644 index a02db40efa7..00000000000 --- a/innobase/com/ts/tscom.c +++ /dev/null @@ -1,94 +0,0 @@ -/************************************************************************ -The test module for communication - -(c) 1995 Innobase Oy - -Created 9/26/1995 Heikki Tuuri -*************************************************************************/ - -#include "../com0com.h" -#include "../com0shm.h" -#include "ut0ut.h" -#include "mem0mem.h" -#include "os0thread.h" -#include "sync0ipm.h" -#include "sync0sync.h" - -byte buf[10000]; -char addr[150]; - -void -test1(void) -/*=======*/ -{ - com_endpoint_t* ep; - ulint ret; - ulint size; - ulint len; - ulint addr_len; - ulint i; - - ep = com_endpoint_create(COM_SHM); - - ut_a(ep); - - size = 8192; - - ret = com_endpoint_set_option(ep, COM_OPT_MAX_DGRAM_SIZE, - (byte*)&size, 0); - - ut_a(ret == 0); - - ret = com_bind(ep, "SRV", 3); - - ut_a(ret == 0); - - printf("Server endpoint created!\n"); - - for (i = 0; i < 50000; i++) { - - ret = com_recvfrom(ep, buf, 10000, &len, addr, 150, &addr_len); - - ut_a(ret == 0); - - buf[len] = '\0'; - addr[addr_len] = '\0'; -/* - printf( - "Message of len %lu\n%s \nreceived from address %s of len %lu\n", - len, buf, addr, addr_len); -*/ - ret = com_sendto(ep, (byte*)"Hello from server!\n", 18, "CLI", 3); - - ut_a(ret == 0); - } - - ret = com_endpoint_free(ep); - - ut_ad(ret == 0); - - printf("Count of extra system calls in com_shm %lu\n", - com_shm_system_call_count); - printf("Count of extra system calls in ip_mutex %lu\n", - ip_mutex_system_call_count); -} - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - sync_init(); - mem_init(); - - oldtm = ut_clock(); - - test1(); - - ut_ad(mem_all_freed()); - - tm = ut_clock(); - printf("Wall clock time for test %ld milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/dict/ts/makefile b/innobase/dict/ts/makefile deleted file mode 100644 index d1a24e90a89..00000000000 --- a/innobase/dict/ts/makefile +++ /dev/null @@ -1,16 +0,0 @@ - - - -include ..\..\makefile.i - -tsdict: ..\dict.lib tsdict.c - $(CCOM) $(CFL) -I.. -I..\.. ..\dict.lib ..\..\data.lib ..\..\buf.lib ..\..\mach.lib ..\..\fil.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsdict.c $(LFL) - - - - - - - - - diff --git a/innobase/dict/ts/tsdict.c b/innobase/dict/ts/tsdict.c deleted file mode 100644 index fa41a6b9112..00000000000 --- a/innobase/dict/ts/tsdict.c +++ /dev/null @@ -1,73 +0,0 @@ -/************************************************************************ -The test module for the data dictionary - -(c) 1996 Innobase Oy - -Created 1/13/1996 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "mem0mem.h" -#include "buf0buf.h" -#include "data0type.h" -#include "..\dict0dict.h" - -/************************************************************************ -Basic test of data dictionary. */ - -void -test1(void) -/*=======*/ -{ - dict_table_t* table; - dict_index_t* index; - - table = dict_table_create("TS_TABLE1", 3); - - dict_table_add_col(table, "COL1", DATA_INT, 3, 4, 5); - dict_table_add_col(table, "COL2", DATA_INT, 3, 4, 5); - dict_table_add_col(table, "COL3", DATA_INT, 3, 4, 5); - - ut_a(0 == dict_table_publish(table)); - - index = dict_index_create("TS_TABLE1", "IND1", - DICT_UNIQUE | DICT_CLUSTERED | DICT_MIX, 2, 1); - - dict_index_add_field(index, "COL2", DICT_DESCEND); - dict_index_add_field(index, "COL1", 0); - - ut_a(0 == dict_index_publish(index)); - - dict_table_print(table); - - dict_table_free(table); - - ut_a(dict_all_freed()); - - dict_free_all(); - - ut_a(dict_all_freed()); -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - oldtm = ut_clock(); - - sync_init(); - mem_init(); - buf_pool_init(100, 100); - dict_init(); - - test1(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/dyn/ts/makefile b/innobase/dyn/ts/makefile deleted file mode 100644 index b4b5ad5eadf..00000000000 --- a/innobase/dyn/ts/makefile +++ /dev/null @@ -1,12 +0,0 @@ - -include ..\..\makefile.i - -tsdyn: ..\dyn.lib tsdyn.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\dyn.lib ..\..\mem.lib ..\..\ut.lib ..\..\mach.lib ..\..\sync.lib ..\..\os.lib tsdyn.c $(LFL) - - - - - - - diff --git a/innobase/dyn/ts/tsdyn.c b/innobase/dyn/ts/tsdyn.c deleted file mode 100644 index 4c21583d9d8..00000000000 --- a/innobase/dyn/ts/tsdyn.c +++ /dev/null @@ -1,57 +0,0 @@ -/************************************************************************ -The test module for dynamic array - -(c) 1996 Innobase Oy - -Created 2/5/1996 Heikki Tuuri -*************************************************************************/ - -#include "../dyn0dyn.h" -#include "sync0sync.h" -#include "mem0mem.h" - -/**************************************************************** -Basic test. */ - -void -test1(void) -/*=======*/ -{ - dyn_array_t dyn; - ulint i; - ulint* ulint_ptr; - - printf("-------------------------------------------\n"); - printf("TEST 1. Basic test\n"); - - dyn_array_create(&dyn); - - for (i = 0; i < 1000; i++) { - ulint_ptr = dyn_array_push(&dyn, sizeof(ulint)); - *ulint_ptr = i; - } - - ut_a(dyn_array_get_n_elements(&dyn) == 1000); - - for (i = 0; i < 1000; i++) { - ulint_ptr = dyn_array_get_nth_element(&dyn, i, sizeof(ulint)); - ut_a(*ulint_ptr == i); - } - - dyn_array_free(&dyn); -} - -void -main(void) -{ - sync_init(); - mem_init(); - - test1(); - - ut_ad(sync_all_freed()); - - ut_ad(mem_all_freed()); - - printf("TEST SUCCESSFULLY COMPLETED!\n"); -} diff --git a/innobase/fil/ts/makefile b/innobase/fil/ts/makefile deleted file mode 100644 index 41911104bc6..00000000000 --- a/innobase/fil/ts/makefile +++ /dev/null @@ -1,15 +0,0 @@ - - - -include ..\..\makefile.i - -tsfil: ..\fil.lib tsfil.c - $(CCOM) $(CFL) -I.. -I..\.. ..\fil.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsfil.c $(LFL) - - - - - - - - diff --git a/innobase/fil/ts/tsfil.c b/innobase/fil/ts/tsfil.c deleted file mode 100644 index 61fdefe28af..00000000000 --- a/innobase/fil/ts/tsfil.c +++ /dev/null @@ -1,329 +0,0 @@ -/************************************************************************ -The test module for the file system - -(c) 1995 Innobase Oy - -Created 10/29/1995 Heikki Tuuri -*************************************************************************/ - -#include "os0thread.h" -#include "os0file.h" -#include "ut0ut.h" -#include "sync0sync.h" -#include "mem0mem.h" -#include "..\fil0fil.h" - -ulint last_thr = 1; - -byte global_buf[10000000]; -byte global_buf2[20000]; - -os_file_t files[1000]; - -os_event_t gl_ready; - -mutex_t ios_mutex; -ulint ios; - -/********************************************************************* -Test for synchronous file io. */ - -void -test1(void) -/*=======*/ -{ - ulint i, j; - void* mess; - bool ret; - void* buf; - ulint rnd, rnd3; - ulint tm, oldtm; - - printf("-------------------------------------------\n"); - printf("FIL-TEST 1. Test of synchronous file io\n"); - - /* Align the buffer for file io */ - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - rnd = ut_time(); - rnd3 = ut_time(); - - rnd = rnd * 3416133; - rnd3 = rnd3 * 6576681; - - oldtm = ut_clock(); - - for (j = 0; j < 300; j++) { - for (i = 0; i < (rnd3 % 15); i++) { - fil_read((rnd % 1000) / 100, rnd % 100, 0, 8192, buf, NULL); - - ut_a(fil_validate()); - - ret = fil_aio_wait(0, &mess); - ut_a(ret); - - ut_a(fil_validate()); - - ut_a(*((ulint*)buf) == rnd % 1000); - - rnd += 1; - } - rnd = rnd + 3416133; - rnd3 = rnd3 + 6576681; - } - - tm = ut_clock(); - printf("Wall clock time for synchr. io %lu milliseconds\n", - tm - oldtm); - -} - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - void* buf; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - printf("Thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - if ((ulint)mess == 3333) { - os_event_set(gl_ready); - } else { - ut_a((ulint)mess == - *((ulint*)((byte*)buf + 8192 * (ulint)mess))); - } - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - ut_a(ret); -/* printf("Message for thread %lu %lu\n", segment, - (ulint)mess); */ - } - - return(0); -} - -/************************************************************************ -Test of io-handler threads */ - -void -test2(void) -/*=======*/ -{ - ulint i; - ulint j; - void* buf; - ulint rnd, rnd3; - ulint tm, oldtm; - os_thread_t thr[5]; - os_thread_id_t id[5]; - ulint n[5]; - - /* Align the buffer for file io */ - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - gl_ready = os_event_create(NULL); - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } - - printf("-------------------------------------------\n"); - printf("FIL-TEST 2. Test of asynchronous file io\n"); - - rnd = ut_time(); - rnd3 = ut_time(); - - rnd = rnd * 3416133; - rnd3 = rnd3 * 6576681; - - oldtm = ut_clock(); - - for (j = 0; j < 300; j++) { - for (i = 0; i < (rnd3 % 15); i++) { - fil_read((rnd % 1000) / 100, rnd % 100, 0, 8192, - (void*)((byte*)buf + 8192 * (rnd % 1000)), - (void*)(rnd % 1000)); - - rnd += 1; - } - ut_a(fil_validate()); - rnd = rnd + 3416133; - rnd3 = rnd3 + 6576681; - } - - ut_a(!os_aio_all_slots_free()); - - tm = ut_clock(); - printf("Wall clock time for asynchr. io %lu milliseconds\n", - tm - oldtm); - - fil_read(5, 25, 0, 8192, - (void*)((byte*)buf + 8192 * 1000), - (void*)3333); - - tm = ut_clock(); - - ut_a(fil_validate()); - - printf("All ios queued! N ios: %lu\n", ios); - - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - os_event_wait(gl_ready); - - tm = ut_clock(); - printf("N ios: %lu\n", ios); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - os_thread_sleep(2000000); - - printf("N ios: %lu\n", ios); - - ut_a(fil_validate()); - ut_a(os_aio_all_slots_free()); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, j, k, n; - void* buf; - void* mess; - char name[10]; - - buf = (void*)(((ulint)global_buf2 + 6300) & (~0xFFF)); - - name[0] = 't'; - name[1] = 's'; - name[2] = 'f'; - name[3] = 'i'; - name[4] = 'l'; - name[5] = 'e'; - name[8] = '\0'; - - for (k = 0; k < 10; k++) { - for (i = 0; i < 20; i++) { - - name[6] = (char)(k + (ulint)'a'); - name[7] = (char)(i + (ulint)'a'); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create(name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } else { - - for (j = 0; j < 5; j++) { - for (n = 0; n < 8192 / sizeof(ulint); n++) { - *((ulint*)buf + n) = - k * 100 + i * 5 + j; - } - - ret = os_aio_write(files[i], buf, 8192 * j, - 0, 8192, NULL); - ut_a(ret); - - ret = os_aio_wait(0, &mess); - - ut_a(ret); - ut_a(mess == NULL); - } - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create("noname", k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, 5, k); - } - } -} - -/************************************************************************ -Frees the spaces in the file system. */ - -void -free_system(void) -/*=============*/ -{ - ulint i; - - for (i = 0; i < 10; i++) { - fil_space_free(i); - } -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - oldtm = ut_clock(); - - os_aio_init(160, 5); - sync_init(); - mem_init(); - fil_init(2); /* Allow only 2 open files at a time */ - - ut_a(fil_validate()); - - create_files(); - - test1(); - - test2(); - - free_system(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/fsp/trash/FSP0FSP.C b/innobase/fsp/trash/FSP0FSP.C deleted file mode 100644 index b0add437bff..00000000000 --- a/innobase/fsp/trash/FSP0FSP.C +++ /dev/null @@ -1,3100 +0,0 @@ -/********************************************************************** -File-space management - -(c) 1995 Innobase Oy - -Created 11/29/1995 Heikki Tuuri -***********************************************************************/ - -#include "fsp0fsp.h" - -#include "buf0buf.h" -#include "fil0fil.h" -#include "sync0sync.h" -#include "mtr0log.h" -#include "fut0fut.h" -#include "ut0byte.h" - -/* The data structures in files are defined just as byte strings in C */ -typedef byte fsp_header_t; -typedef byte xdes_t; -typedef byte fseg_page_header_t; - -/* Rw-latch protecting the whole file space system */ -rw_lock_t fsp_latch; - - -/* SPACE HEADER - ============ - -File space header data structure: this data structure -is contained in the first page of a space. The space for this header -is reserved in every extent descriptor page, but used only in the first. */ -#define FSP_HEADER_OFFSET FIL_PAGE_DATA /* Offset of the space header - within a file page */ -/*-------------------------------------*/ -#define FSP_SIZE 0 /* Current - size of the space in pages */ -#define FSP_FREE_LIMIT 4 /* Minimum page number for which - the free list has not been initialized: - the pages >= this limit are, by - definition, free */ -#define FSP_LOWEST_NO_WRITE 8 /* The lowest page offset for which - the page has not been written to disk - (if it has been written, we know - that the OS has really reserved - the physical space for the page) */ -#define FSP_FRAG_N_USED 12 /* number of used pages in - the FSP_FREE_FRAG list */ -#define FSP_FREE 16 /* list of free extents */ -#define FSP_FREE_FRAG (16 + FLST_BASE_NODE_SIZE) - /* list of partially free extents not - belonging to any segment */ -#define FSP_FULL_FRAG (16 + 2 * FLST_BASE_NODE_SIZE) - /* list of full extents not belonging - to any segment */ -#define FSP_SEG_ID (16 + 3 * FLST_BASE_NODE_SIZE) - /* 8 bytes which give the first -#define FSP_SEG_HDRS_FULL (24 + 3 * FLST_BASE_NODE_SIZE) - /* list of pages containing segment - headers, where all the segment header - slots are reserved */ -#define FSP_SEG_HDRS_FREE (24 + 4 * FLST_BASE_NODE_SIZE) - /* list of pages containing segment - headers, where not all the segment - header slots are reserved */ -/*-------------------------------------*/ -/* File space header size */ -#define FSP_HEADER_SIZE (24 + 4 * FLST_BASE_NODE_SIZE) - -#define FSP_FREE_ADD 4 /* this many free extents are added - to the free list from above - FSP_FREE_LIMIT at a time */ - - -/* SEGMENT HEADER - ============== - -Segment header which is created for each segment in a tablespace, on a -page of its own. NOTE: in purge we assume that a segment having only one -currently used page can be freed in a few steps, so that the freeing cannot -fill the file buffer with bufferfixed file pages. */ - -#define FSEG_HDR_PAGE_NODE FSEG_PAGE_DATA - /* the list node for linking - segment header pages */ - -#define FSEG_ARR_OFFSET (FSEG_PAGE_DATA + FLST_NODE_SIZE) -/*-------------------------------------*/ -#define FSEG_ID 0 /* 8 bytes of segment id: if this is - ut_dulint_zero, it means that the - header is unused */ -#define FSEG_NOT_FULL_N_USED 8 - /* number of used segment pages in - the FSEG_NOT_FULL list */ -#define FSEG_FREE 12 - /* list of free extents of this - segment */ -#define FSEG_NOT_FULL (12 + FLST_BASE_NODE_SIZE) - /* list of partially free extents */ -#define FSEG_FULL (12 + 2 * FLST_BASE_NODE_SIZE) - /* list of full extents */ -#define FSEG_MAGIC_N (12 + 3 * FLST_BASE_NODE_SIZE) - /* magic number used in debugging */ -#define FSEG_FRAG_ARR (16 + 3 * FLST_BASE_NODE_SIZE) - /* array of individual pages - belonging to this segment in fsp - fragment extent lists */ -#define FSEG_FRAG_ARR_N_SLOTS (FSP_EXTENT_SIZE / 2) - /* number of slots in the array for - the fragment pages */ -#define FSEG_FRAG_SLOT_SIZE 4 /* a fragment page slot contains its - page number within space, FIL_NULL - means that the slot is not in use */ -/*-------------------------------------*/ -#define FSEG_HEADER_SIZE (16 + 3 * FLST_BASE_NODE_SIZE +\ - FSEG_FRAG_ARR_N_SLOTS * FSEG_FRAG_SLOT_SIZE) - -#define FSP_SEG_HDRS_PER_PAGE ((UNIV_PAGE_SIZE - FSEG_ARR_OFFSET - 10)\ - / FSEG_HEADER_SIZE) - /* Number of segment headers which fit on a - single page */ - -#define FSEG_MAGIC_N_VALUE 97937874 - -#define FSEG_FILLFACTOR 8 /* If this value is x, then if - the number of unused but reserved - pages in a segment is less than - reserved pages * 1/x, and there are - at least FSEG_FRAG_LIMIT used pages, - then we allow a new empty extent to - be added to the segment in - fseg_alloc_free_page. Otherwise, we - use unused pages of the segment. */ - -#define FSEG_FRAG_LIMIT FSEG_FRAG_N_ARR_SLOTS - /* If the segment has >= this many - used pages, it may be expanded by - allocating extents to the segment; - until that only individual fragment - pages are allocated from the space */ - -#define FSEG_FREE_LIST_LIMIT 40 /* If the reserved size of a segment - is at least this many extents, we - allow extents to be put to the free - list of the extent: at most - FSEG_FREE_LIST_MAX_LEN many */ -#define FSEG_FREE_LIST_MAX_LEN 4 - - -/* EXTENT DESCRIPTOR - ================= - -File extent descriptor data structure: contains bits to tell -which pages in the extent are free and which contain old tuple -version to clean. */ - -/*-------------------------------------*/ -#define XDES_ID 0 /* The identifier of the segment - to which this extent belongs */ -#define XDES_FLST_NODE 8 /* The list node data structure - for the descriptors */ -#define XDES_STATE (FLST_NODE_SIZE + 8) - /* contains state information - of the extent */ -#define XDES_BITMAP (FLST_NODE_SIZE + 12) - /* Descriptor bitmap of the pages - in the extent*/ -/*-------------------------------------*/ - -#define XDES_BITS_PER_PAGE 2 /* How many bits are there per page */ -#define XDES_FREE_BIT 0 /* Index of the bit which tells if - the page is free */ -#define XDES_CLEAN_BIT 1 /* Index of the bit which tells if - there are old versions of tuples - on the page */ -/* States of a descriptor */ -#define XDES_FREE 1 /* extent is in free list of space */ -#define XDES_FREE_FRAG 2 /* extent is in free fragment list of - space */ -#define XDES_FULL_FRAG 3 /* extent is in full fragment list of - space */ -#define XDES_FSEG 4 /* extent belongs to a segment*/ - -/* Number of pages described in a single descriptor page: -currently each page description takes less than -1 byte. */ -#define XDES_DESCRIBED_PER_PAGE UNIV_PAGE_SIZE - -/* File extent data structure size in bytes. The "+ 7 ) / 8" -part in the definition rounds the number of bytes upward. */ -#define XDES_SIZE (XDES_BITMAP +\ - (FSP_EXTENT_SIZE * XDES_BITS_PER_PAGE + 7) / 8) - -/* Offset of the descriptor array on a descriptor page */ -#define XDES_ARR_OFFSET (FSP_HEADER_OFFSET + FSP_HEADER_SIZE) - -/************************************************************************** -Returns an extent to the free list of a space. */ -static -void -fsp_free_extent( -/*============*/ - ulint space, /* in: space id */ - ulint page, /* in: page offset in the extent */ - mtr_t* mtr); /* in: mtr */ -/************************************************************************** -Frees an extent of a segment to the space free list. */ -static -void -fseg_free_extent( -/*=============*/ - fseg_header_t* seg_header, /* in: segment header */ - ulint space, /* in: space id */ - ulint page, /* in: page offset in the extent */ - mtr_t* mtr); /* in: mtr handle */ -/************************************************************************** -Calculates the number of pages reserved by a segment, and how -many pages are currently used. */ -static -ulint -fseg_n_reserved_pages_low( -/*======================*/ - /* out: number of reserved pages */ - fseg_header_t* header, /* in: segment header */ - ulint* used, /* out: number of pages used (<= reserved) */ - mtr_t* mtr); /* in: mtr handle */ -/************************************************************************ -Marks a page used. The page must reside within the extents of the given -segment. */ -static -void -fseg_mark_page_used( -/*================*/ - fseg_header_t* seg_header,/* in: segment header */ - ulint space, /* in: space id */ - ulint page, /* in: page offset */ - mtr_t* mtr); /* in: mtr */ -/************************************************************************** -Frees a single page of a segment. */ -static -void -fseg_free_page_low( -/*===============*/ - fseg_header_t* seg_header, /* in: segment header */ - ulint space, /* in: space id */ - ulint page, /* in: page offset */ - mtr_t* mtr); /* in: mtr handle */ -/************************************************************************** -Returns the first extent descriptor for a segment. We think of the extent -lists of the segment catenated in the order FSEG_FULL -> FSEG_NOT_FULL --> FSEG_FREE. */ -static -xdes_t* -fseg_get_first_extent( -/*==================*/ - /* out: the first extent descriptor, or NULL if - none */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr); /* in: mtr */ -/************************************************************************** -Puts new extents to the free list if -there are free extents above the free limit. If an extent happens -to contain an extent descriptor page, the extent is put to -the FSP_FREE_FRAG list with the page marked as used. */ -static -void -fsp_fill_free_list( -/*===============*/ - ulint space, /* in: space */ - fsp_header_t* header, /* in: space header */ - mtr_t* mtr); /* in: mtr */ - -/************************************************************************** -Gets a descriptor bit of a page. */ -UNIV_INLINE -bool -xdes_get_bit( -/*=========*/ - /* out: TRUE if free */ - xdes_t* descr, /* in: descriptor */ - ulint bit, /* in: XDES_FREE_BIT or XDES_CLEAN_BIT */ - ulint offset, /* in: page offset within extent: - 0 ... FSP_EXTENT_SIZE - 1 */ - mtr_t* mtr) /* in: mtr */ -{ - ulint index; - ulint byte_index; - ulint bit_index; - - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - ut_ad((bit == XDES_FREE_BIT) || (bit == XDES_CLEAN_BIT)); - ut_ad(offset < FSP_EXTENT_SIZE); - - index = bit + XDES_BITS_PER_PAGE * offset; - - byte_index = index / 8; - bit_index = index % 8; - - return(ut_bit_get_nth( - mtr_read_ulint(descr + XDES_BITMAP + byte_index, - MLOG_1BYTE, mtr), - bit_index)); -} - -/************************************************************************** -Sets a descriptor bit of a page. */ -UNIV_INLINE -void -xdes_set_bit( -/*=========*/ - xdes_t* descr, /* in: descriptor */ - ulint bit, /* in: XDES_FREE_BIT or XDES_CLEAN_BIT */ - ulint offset, /* in: page offset within extent: - 0 ... FSP_EXTENT_SIZE - 1 */ - bool val, /* in: bit value */ - mtr_t* mtr) /* in: mtr */ -{ - ulint index; - ulint byte_index; - ulint bit_index; - ulint descr_byte; - - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - ut_ad((bit == XDES_FREE_BIT) || (bit == XDES_CLEAN_BIT)); - ut_ad(offset < FSP_EXTENT_SIZE); - - index = bit + XDES_BITS_PER_PAGE * offset; - - byte_index = index / 8; - bit_index = index % 8; - - descr_byte = mtr_read_ulint(descr + XDES_BITMAP + byte_index, - MLOG_1BYTE, mtr); - - descr_byte = ut_bit_set_nth(descr_byte, bit_index, val); - - mlog_write_ulint(descr + XDES_BITMAP + byte_index, - descr_byte, MLOG_1BYTE, mtr); -} - -/************************************************************************** -Looks for a descriptor bit having the desired value. Starts from hint -and scans upward; at the end of the extent the search is wrapped to -the start of the extent. */ -UNIV_INLINE -ulint -xdes_find_bit( -/*==========*/ - /* out: bit index of the bit, - ULINT_UNDEFINED if not found */ - xdes_t* descr, /* in: descriptor */ - ulint bit, /* in: XDES_FREE_BIT or XDES_CLEAN_BIT */ - bool val, /* in: desired bit value */ - ulint hint, /* in: hint of which bit position would be - desirable */ - mtr_t* mtr) /* in: mtr */ -{ - ulint i; - - ut_ad(descr && mtr); - ut_ad(val <= TRUE); - ut_ad(hint < FSP_EXTENT_SIZE); - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - - for (i = hint; i < FSP_EXTENT_SIZE; i++) { - if (val == xdes_get_bit(descr, bit, i, mtr)) { - return(i); - } - } - - for (i = 0; i < hint; i++) { - if (val == xdes_get_bit(descr, bit, i, mtr)) { - return(i); - } - } - - return(ULINT_UNDEFINED); -} - -/************************************************************************** -Looks for a descriptor bit having the desired value. Scans the extent in -a direction opposite to xdes_find_bit. */ -UNIV_INLINE -ulint -xdes_find_bit_downward( -/*===================*/ - /* out: bit index of the bit, - ULINT_UNDEFINED if not found */ - xdes_t* descr, /* in: descriptor */ - ulint bit, /* in: XDES_FREE_BIT or XDES_CLEAN_BIT */ - bool val, /* in: desired bit value */ - ulint hint, /* in: hint of which bit position would be - desirable */ - mtr_t* mtr) /* in: mtr */ -{ - ulint i; - - ut_ad(descr && mtr); - ut_ad(val <= TRUE); - ut_ad(hint < FSP_EXTENT_SIZE); - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - - for (i = hint + 1; i > 0; i--) { - if (val == xdes_get_bit(descr, bit, i - 1, mtr)) { - return(i - 1); - } - } - - for (i = FSP_EXTENT_SIZE - 1; i > hint; i--) { - if (val == xdes_get_bit(descr, bit, i, mtr)) { - return(i); - } - } - - return(ULINT_UNDEFINED); -} - -/************************************************************************** -Returns the number of used pages in a descriptor. */ -UNIV_INLINE -ulint -xdes_get_n_used( -/*============*/ - /* out: number of pages used */ - xdes_t* descr, /* in: descriptor */ - mtr_t* mtr) /* in: mtr */ -{ - ulint i; - ulint count = 0; - - ut_ad(descr && mtr); - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - - for (i = 0; i < FSP_EXTENT_SIZE; i++) { - if (FALSE == xdes_get_bit(descr, XDES_FREE_BIT, i, mtr)) { - count++; - } - } - - return(count); -} - -/************************************************************************** -Returns true if extent contains no used pages. */ -UNIV_INLINE -bool -xdes_is_free( -/*=========*/ - /* out: TRUE if totally free */ - xdes_t* descr, /* in: descriptor */ - mtr_t* mtr) /* in: mtr */ -{ - if (0 == xdes_get_n_used(descr, mtr)) { - return(TRUE); - } else { - return(FALSE); - } -} - -/************************************************************************** -Returns true if extent contains no free pages. */ -UNIV_INLINE -bool -xdes_is_full( -/*=========*/ - /* out: TRUE if full */ - xdes_t* descr, /* in: descriptor */ - mtr_t* mtr) /* in: mtr */ -{ - if (FSP_EXTENT_SIZE == xdes_get_n_used(descr, mtr)) { - return(TRUE); - } else { - return(FALSE); - } -} - -/************************************************************************** -Sets the state of an xdes. */ -UNIV_INLINE -void -xdes_set_state( -/*===========*/ - xdes_t* descr, /* in: descriptor */ - ulint state, /* in: state to set */ - mtr_t* mtr) /* in: mtr handle */ -{ - ut_ad(descr && mtr); - ut_ad(state >= XDES_FREE); - ut_ad(state <= XDES_FSEG); - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - - mlog_write_ulint(descr + XDES_STATE, state, MLOG_4BYTES, mtr); -} - -/************************************************************************** -Gets the state of an xdes. */ -UNIV_INLINE -ulint -xdes_get_state( -/*===========*/ - /* out: state */ - xdes_t* descr, /* in: descriptor */ - mtr_t* mtr) /* in: mtr handle */ -{ - ut_ad(descr && mtr); - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - - return(mtr_read_ulint(descr + XDES_STATE, MLOG_4BYTES, mtr)); -} - -/************************************************************************** -Inits an extent descriptor to free and clean state. */ -UNIV_INLINE -void -xdes_init( -/*======*/ - xdes_t* descr, /* in: descriptor */ - mtr_t* mtr) /* in: mtr */ -{ - ulint i; - - ut_ad(descr && mtr); - ut_ad(mtr_memo_contains(mtr, buf_block_align(descr), - MTR_MEMO_PAGE_X_LOCK)); - - for (i = 0; i < FSP_EXTENT_SIZE; i++) { - xdes_set_bit(descr, XDES_FREE_BIT, i, TRUE, mtr); - xdes_set_bit(descr, XDES_CLEAN_BIT, i, TRUE, mtr); - } - - xdes_set_state(descr, XDES_FREE, mtr); -} - -/************************************************************************ -Calculates the page where the descriptor of a page resides. */ -UNIV_INLINE -ulint -xdes_calc_descriptor_page( -/*======================*/ - /* out: descriptor page offset */ - ulint offset) /* in: page offset */ -{ - ut_ad(UNIV_PAGE_SIZE > XDES_ARR_OFFSET - + (XDES_DESCRIBED_PER_PAGE / FSP_EXTENT_SIZE) * XDES_SIZE); - - return(ut_2pow_round(offset, XDES_DESCRIBED_PER_PAGE)); -} - -/************************************************************************ -Calculates the descriptor index within a descriptor page. */ -UNIV_INLINE -ulint -xdes_calc_descriptor_index( -/*=======================*/ - /* out: descriptor index */ - ulint offset) /* in: page offset */ -{ - return(ut_2pow_remainder(offset, XDES_DESCRIBED_PER_PAGE) / - FSP_EXTENT_SIZE); -} - -/************************************************************************ -Gets pointer to a the extent descriptor of a page. The page where the -extent descriptor resides is x-locked. If the page offset is equal to the free -limit of the space, adds new extents from above the free limit -to the space free list, if not free limit == space size. This adding -is necessary to make the descriptor defined, as they are uninitialized -above the free limit. */ -UNIV_INLINE -xdes_t* -xdes_get_descriptor_with_space_hdr( -/*===============================*/ - /* out: pointer to the extent descriptor, - NULL if the page does not exist in the - space or if offset > free limit */ - fsp_header_t* sp_header,/* in: space header, x-latched */ - ulint space, /* in: space id */ - ulint offset, /* in: page offset; - if equal to the free limit, - we try to add new extents to - the space free list */ - mtr_t* mtr) /* in: mtr handle */ -{ - ulint limit; - ulint size; - buf_block_t* buf_page; - ulint descr_page_no; - page_t* descr_page; - - ut_ad(mtr); - ut_ad(mtr_memo_contains(mtr, &fsp_latch, MTR_MEMO_X_LOCK)); - - /* Read free limit and space size */ - limit = mtr_read_ulint(sp_header + FSP_FREE_LIMIT, MLOG_4BYTES, mtr); - size = mtr_read_ulint(sp_header + FSP_SIZE, MLOG_4BYTES, mtr); - - /* If offset is >= size or > limit, return NULL */ - if ((offset >= size) || (offset > limit)) { - return(NULL); - } - - /* If offset is == limit, fill free list of the space. */ - if (offset == limit) { - fsp_fill_free_list(space, sp_header, mtr); - } - - descr_page_no = xdes_calc_descriptor_page(offset); - - if (descr_page_no == 0) { - /* It is on the space header page */ - - descr_page = buf_frame_align(sp_header); - } else { - - buf_page = buf_page_get(space, descr_page_no, mtr); - buf_page_x_lock(buf_page, mtr); - descr_page = buf_block_get_frame(buf_page); - } - - return(descr_page + XDES_ARR_OFFSET - + XDES_SIZE * xdes_calc_descriptor_index(offset)); -} - -/************************************************************************ -Gets pointer to a the extent descriptor of a page. The page where the -extent descriptor resides is x-locked. If the page offset is equal to the free -limit of the space, adds new extents from above the free limit -to the space free list, if not free limit == space size. This adding -is necessary to make the descriptor defined, as they are uninitialized -above the free limit. */ -static -xdes_t* -xdes_get_descriptor( -/*================*/ - /* out: pointer to the extent descriptor, - NULL if the page does not exist in the - space or if offset > free limit */ - ulint space, /* in: space id */ - ulint offset, /* in: page offset; - if equal to the free limit, - we try to add new extents to - the space free list */ - mtr_t* mtr) /* in: mtr handle */ -{ - fsp_header_t* sp_header; - buf_block_t* block; - - block = buf_page_get(space, 0, mtr); /* get space header */ - sp_header = FSP_HEADER_OFFSET + buf_block_get_frame(block); - buf_page_x_lock(block, mtr); - - return(xdes_get_descriptor_with_space_hdr(sp_header, space, offset, - mtr)); -} - -/************************************************************************ -Gets pointer to a the extent descriptor if the file address -of the descriptor list node is known. The page where the -extent descriptor resides is x-locked. */ -UNIV_INLINE -xdes_t* -xdes_lst_get_descriptor( -/*====================*/ - /* out: pointer to the extent descriptor */ - ulint space, /* in: space id */ - fil_addr_t lst_node,/* in: file address of the list node - contained in the descriptor */ - mtr_t* mtr) /* in: mtr handle */ -{ - xdes_t* descr; - - ut_ad(mtr); - ut_ad(mtr_memo_contains(mtr, &fsp_latch, MTR_MEMO_X_LOCK)); - - descr = fut_get_ptr_x_lock(space, lst_node, mtr) - XDES_FLST_NODE; - - return(descr); -} - -/************************************************************************ -Gets pointer to the next descriptor in a descriptor list and x-locks -its page. */ -UNIV_INLINE -xdes_t* -xdes_lst_get_next( -/*==============*/ - xdes_t* descr, /* in: pointer to a descriptor */ - mtr_t* mtr) /* in: mtr handle */ -{ - ulint space; - - ut_ad(mtr && descr); - - space = buf_page_get_space(buf_block_align(descr)); - - return(xdes_lst_get_descriptor(space, - flst_get_next_addr(descr + XDES_FLST_NODE, mtr), mtr)); -} - -/************************************************************************ -Returns page offset of the first page in extent described by a descriptor. -*/ -UNIV_INLINE -ulint -xdes_get_offset( -/*============*/ - /* out: offset of the first page in extent */ - xdes_t* descr) /* in: extent descriptor */ -{ - buf_block_t* buf_page; - - ut_ad(descr); - - buf_page = buf_block_align(descr); - - return(buf_page_get_offset(buf_page) - + ((descr - buf_frame_align(descr) - XDES_ARR_OFFSET) - / XDES_SIZE) - * FSP_EXTENT_SIZE); -} - -/************************************************************************** -Gets a pointer to the space header and x-locks its page. */ -UNIV_INLINE -fsp_header_t* -fsp_get_space_header( -/*=================*/ - /* out: pointer to the space header, page x-locked */ - ulint id, /* in: space id */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - - ut_ad(mtr); - - block = buf_page_get(id, 0, mtr); - - buf_page_x_lock(block, mtr); - - return(FSP_HEADER_OFFSET + buf_block_get_frame(block)); -} - -/************************************************************************** -Initializes the file space system mutex. */ - -void -fsp_init(void) -/*==========*/ -{ - rw_lock_create(&fsp_latch); -} - -/************************************************************************** -Initializes the space header of a new created space. */ - -void -fsp_header_init( -/*============*/ - ulint space, /* in: space id */ - ulint size, /* in: current size in blocks */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - fsp_header_t* header; - - ut_ad(mtr); - - mtr_x_lock(&fsp_latch, mtr); - - header = fsp_get_space_header(space, mtr); - - mlog_write_ulint(header + FSP_SIZE, size, MLOG_4BYTES, mtr); - mlog_write_ulint(header + FSP_FREE_LIMIT, 0, MLOG_4BYTES, mtr); - mlog_write_ulint(header + FSP_LOWEST_NO_WRITE, 0, MLOG_4BYTES, mtr); - mlog_write_ulint(header + FSP_FRAG_N_USED, 0, MLOG_4BYTES, mtr); - - flst_init(header + FSP_FREE, mtr); - flst_init(header + FSP_FREE_FRAG, mtr); - flst_init(header + FSP_FULL_FRAG, mtr); - flst_init(header + FSP_SEG_HDRS_FULL, mtr); - flst_init(header + FSP_SEG_HDRS_FREE, mtr); - - mlog_write_dulint(header + FSP_SEG_ID, ut_dulint_create(0, 1), - MLOG_8BYTES, mtr); -} - -/************************************************************************** -Increases the space size field of a space. */ - -void -fsp_header_inc_size( -/*================*/ - ulint space, /* in: space id */ - ulint size_inc,/* in: size increment in pages */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - fsp_header_t* header; - ulint size; - - ut_ad(mtr); - - mtr_x_lock(&fsp_latch, mtr); - - header = fsp_get_space_header(space, mtr); - - size = mtr_read_ulint(header + FSP_SIZE, MLOG_4BYTES, mtr); - mlog_write_ulint(header + FSP_SIZE, size + size_inc, MLOG_4BYTES, mtr); -} - -/************************************************************************** -Puts new extents to the free list if there are free extents above the free -limit. If an extent happens to contain an extent descriptor page, the extent -is put to the FSP_FREE_FRAG list with the page marked as used. */ -static -void -fsp_fill_free_list( -/*===============*/ - ulint space, /* in: space */ - fsp_header_t* header, /* in: space header */ - mtr_t* mtr) /* in: mtr */ -{ - ulint limit; - ulint size; - ulint i; - xdes_t* descr; - ulint count = 0; - ulint frag_n_used; - - ut_ad(header && mtr); - - /* Check if we can fill free list from above the free list limit */ - size = mtr_read_ulint(header + FSP_SIZE, MLOG_4BYTES, mtr); - limit = mtr_read_ulint(header + FSP_FREE_LIMIT, MLOG_4BYTES, mtr); - - i = limit; - while ((i + FSP_EXTENT_SIZE <= size) && (count < FSP_FREE_ADD)) { - mlog_write_ulint(header + FSP_FREE_LIMIT, - i + FSP_EXTENT_SIZE, MLOG_4BYTES, mtr); - - descr = xdes_get_descriptor_with_space_hdr(header, space, i, - mtr); - xdes_init(descr, mtr); - - ut_ad(XDES_DESCRIBED_PER_PAGE % FSP_EXTENT_SIZE == 0); - - if (0 == i % XDES_DESCRIBED_PER_PAGE) { - /* The first page in the extent is a descriptor page: - mark it used */ - xdes_set_bit(descr, XDES_FREE_BIT, 0, FALSE, mtr); - xdes_set_state(descr, XDES_FREE_FRAG, mtr); - flst_add_last(header + FSP_FREE_FRAG, - descr + XDES_FLST_NODE, mtr); - frag_n_used = mtr_read_ulint(header + FSP_FRAG_N_USED, - MLOG_4BYTES, mtr); - mlog_write_ulint(header + FSP_FRAG_N_USED, - frag_n_used + 1, - MLOG_4BYTES, mtr); - } else { - flst_add_last(header + FSP_FREE, - descr + XDES_FLST_NODE, mtr); - count++; - } - i += FSP_EXTENT_SIZE; - } -} - -/************************************************************************** -Allocates a new free extent. */ -static -xdes_t* -fsp_alloc_free_extent( -/*==================*/ - /* out: extent descriptor, NULL if cannot - be allocated */ - ulint space, /* in: space id */ - ulint hint, /* in: hint of which extent would be - desirable: any page offset in the extent - goes; the hint must not be > FSP_FREE_LIMIT */ - mtr_t* mtr) /* in: mtr */ -{ - fsp_header_t* header; - fil_addr_t first; - xdes_t* descr; - - ut_ad(mtr); - - header = fsp_get_space_header(space, mtr); - - descr = xdes_get_descriptor_with_space_hdr(header, space, hint, mtr); - - if (descr && (xdes_get_state(descr, mtr) == XDES_FREE)) { - /* Ok, we can take this extent */ - } else { - /* Take the first extent in the free list */ - first = flst_get_first(header + FSP_FREE, mtr); - - if (fil_addr_is_null(first)) { - fsp_fill_free_list(space, header, mtr); - first = flst_get_first(header + FSP_FREE, mtr); - } - - if (fil_addr_is_null(first)) { - return(NULL); /* No free extents left */ - } - - descr = xdes_lst_get_descriptor(space, first, mtr); - } - - flst_remove(header + FSP_FREE, descr + XDES_FLST_NODE, mtr); - - return(descr); -} - -/************************************************************************** -Allocates a single free page from a space. The page is marked as used. */ -static -ulint -fsp_alloc_free_page( -/*================*/ - /* out: the page offset, FIL_NULL - if no page could be allocated */ - ulint space, /* in: space id */ - ulint hint, /* in: hint of which page would be desirable */ - mtr_t* mtr) /* in: mtr handle */ -{ - fsp_header_t* header; - fil_addr_t first; - xdes_t* descr; - ulint free; - ulint frag_n_used; - - ut_ad(mtr); - - header = fsp_get_space_header(space, mtr); - - /* Get the hinted descriptor */ - descr = xdes_get_descriptor_with_space_hdr(header, space, hint, mtr); - - if (descr && (xdes_get_state(descr, mtr) == XDES_FREE_FRAG)) { - /* Ok, we can take this extent */ - } else { - /* Else take the first extent in free_frag list */ - first = flst_get_first(header + FSP_FREE_FRAG, mtr); - - if (fil_addr_is_null(first)) { - /* There are no partially full fragments: allocate - a free extent and add it to the FREE_FRAG - list. NOTE that the allocation may have as a - side-effect that an extent containing a descriptor - page is added to the FREE_FRAG list. But we will - allocate our page from the allocated free extent. */ - - descr = fsp_alloc_free_extent(space, hint, mtr); - - if (descr == NULL) { - /* No free space left */ - return(FIL_NULL); - } - - xdes_set_state(descr, XDES_FREE_FRAG, mtr); - flst_add_last(header + FSP_FREE_FRAG, - descr + XDES_FLST_NODE, mtr); - } else { - descr = xdes_lst_get_descriptor(space, first, mtr); - } - - /* Reset the hint */ - hint = 0; - } - - /* Now we have in descr an extent with at least one free page. - Look for a free page in the extent. */ - free = xdes_find_bit(descr, XDES_FREE_BIT, TRUE, - hint % FSP_EXTENT_SIZE, mtr); - ut_a(free != ULINT_UNDEFINED); - - xdes_set_bit(descr, XDES_FREE_BIT, free, FALSE, mtr); - - /* Update the FRAG_N_USED field */ - frag_n_used = mtr_read_ulint(header + FSP_FRAG_N_USED, - MLOG_4BYTES, mtr); - frag_n_used++; - mlog_write_ulint(header + FSP_FRAG_N_USED, frag_n_used, - MLOG_4BYTES, mtr); - - if (xdes_is_full(descr, mtr)) { - /* The fragment is full: move it to another list */ - flst_remove(header + FSP_FREE_FRAG, - descr + XDES_FLST_NODE, mtr); - xdes_set_state(descr, XDES_FULL_FRAG, mtr); - flst_add_last(header + FSP_FULL_FRAG, - descr + XDES_FLST_NODE, mtr); - mlog_write_ulint(header + FSP_FRAG_N_USED, - frag_n_used - FSP_EXTENT_SIZE, - MLOG_4BYTES, mtr); - } - return(xdes_get_offset(descr) + free); -} - -/************************************************************************** -Frees a single page of a space. The page is marked as free and clean. */ -static -void -fsp_free_page( -/*==========*/ - ulint space, /* in: space id */ - ulint page, /* in: page offset */ - mtr_t* mtr) /* in: mtr handle */ -{ - fsp_header_t* header; - xdes_t* descr; - ulint state; - ulint frag_n_used; - - ut_ad(mtr); - - header = fsp_get_space_header(space, mtr); - - descr = xdes_get_descriptor_with_space_hdr(header, space, page, mtr); - - state = xdes_get_state(descr, mtr); - - ut_a((state == XDES_FREE_FRAG) || (state == XDES_FULL_FRAG)); - - ut_a(xdes_get_bit(descr, XDES_FREE_BIT, page % FSP_EXTENT_SIZE, mtr) - == FALSE); - - xdes_set_bit(descr, XDES_FREE_BIT, page % FSP_EXTENT_SIZE, TRUE, mtr); - xdes_set_bit(descr, XDES_CLEAN_BIT, page % FSP_EXTENT_SIZE, TRUE, mtr); - - frag_n_used = mtr_read_ulint(header + FSP_FRAG_N_USED, - MLOG_4BYTES, mtr); - - if (state == XDES_FULL_FRAG) { - /* The fragment was full: move it to another list */ - flst_remove(header + FSP_FULL_FRAG, - descr + XDES_FLST_NODE, mtr); - xdes_set_state(descr, XDES_FREE_FRAG, mtr); - flst_add_last(header + FSP_FREE_FRAG, - descr + XDES_FLST_NODE, mtr); - mlog_write_ulint(header + FSP_FRAG_N_USED, - frag_n_used + FSP_EXTENT_SIZE - 1, - MLOG_4BYTES, mtr); - } else { - ut_a(frag_n_used > 0); - mlog_write_ulint(header + FSP_FRAG_N_USED, frag_n_used - 1, - MLOG_4BYTES, mtr); - } - - if (xdes_is_free(descr, mtr)) { - /* The extent has become free: move it to another list */ - flst_remove(header + FSP_FREE_FRAG, - descr + XDES_FLST_NODE, mtr); - fsp_free_extent(space, page, mtr); - } -} - -/************************************************************************** -Returns an extent to the free list of a space. */ -static -void -fsp_free_extent( -/*============*/ - ulint space, /* in: space id */ - ulint page, /* in: page offset in the extent */ - mtr_t* mtr) /* in: mtr */ -{ - fsp_header_t* header; - xdes_t* descr; - - ut_ad(mtr); - - header = fsp_get_space_header(space, mtr); - - descr = xdes_get_descriptor_with_space_hdr(header, space, page, mtr); - - ut_a(xdes_get_state(descr, mtr) != XDES_FREE); - - xdes_init(descr, mtr); - - flst_add_last(header + FSP_FREE, descr + XDES_FLST_NODE, mtr); -} - -/************************************************************************** -Looks for an unused segment header on a segment header page. */ -UNIV_INLINE -fseg_header_t* -fsp_seg_hdr_page_get_nth_hdr( -/*=========================*/ - /* out: segment header */ - page_t* page, /* in: segment header page */ - ulint i, /* in: search forward starting from this index */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - ut_ad(i < FSP_SEG_HDRS_PER_PAGE); - ut_ad(mtr_memo_contains(mtr, page, MTR_MEMO_PAGE_X_LOCK)); - - return(page + FSEG_ARR_OFFSET + FSEG_HEADER_SIZE * i); -} - -/************************************************************************** -Looks for a used segment header on a segment header page. */ -static -ulint -fsp_seg_hdr_page_find_used( -/*=======================*/ - /* out: segment header index, or ULINT_UNDEFINED - if not found */ - page_t* page, /* in: segment header page */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - ulint i; - fseg_header_t* header; - - for (i = 0; i < FSP_SEG_HDRS_PER_PAGE; i++) { - - header = fsp_seg_hdr_page_get_nth_hdr(page, i, mtr); - - if (ut_dulint_cmp(mach_read_from_8(header + FSEG_ID), - ut_dulint_zero) != 0) { - /* This is used */ - - return(i); - } - } - - return(ULINT_UNDEFINED); -} - -/************************************************************************** -Looks for an unused segment header on a segment header page. */ -static -ulint -fsp_seg_hdr_page_find_free( -/*=======================*/ - /* out: segment header index, or ULINT_UNDEFINED - if not found */ - page_t* page, /* in: segment header page */ - ulint j, /* in: search forward starting from this index */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - ulint i; - fseg_header_t* header; - - for (i = j; i < FSP_SEG_HDRS_PER_PAGE; i++) { - - header = fsp_seg_hdr_page_get_nth_hdr(page, i, mtr); - - if (ut_dulint_cmp(mach_read_from_8(header + FSEG_ID), - ut_dulint_zero) == 0) { - /* This is unused */ - - return(i); - } - } - - return(ULINT_UNDEFINED); -} - -/************************************************************************** -Allocates a new file segment header page. */ -static -bool -fsp_alloc_seg_hdr_page( -/*===================*/ - /* out: TRUE if could be allocated */ - fsp_header_t* space_header, /* in: space header */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - buf_block_t* block; - ulint page_no; - page_t* page; - fseg_header_t* header; - ulint i; - - page_no = fsp_alloc_free_page(buf_frame_get_space(space_header), - 0, mtr); - if (page_no == FIL_NULL) { - - return(FALSE); - } - - block = buf_page_get(buf_frame_get_space(space_header), page_no, mtr); - - buf_page_x_lock(block, mtr); - - page = buf_block_get_frame(block); - - for (i = 0; i < FSP_SEG_HDRS_PER_PAGE; i++) { - - header = fsp_seg_hdr_page_get_nth_hdr(page, i, mtr); - - mlog_write_dulint(header + FSEG_ID, ut_dulint_zero, - MLOG_8BYTES, mtr); - } - - flst_add_last(space_header + FSP_SEG_HDRS_FREE, - page + FSEG_HDR_PAGE_NODE, mtr); - return(TRUE); -} - -/************************************************************************** -Allocates a new file segment header. */ -static -fseg_header_t* -fsp_alloc_seg_header( -/*=================*/ - /* out: segment header, or NULL if - not enough space */ - fsp_header_t* space_header, /* in: space header */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - buf_block_t* block; - ulint page_no; - page_t* page; - fseg_header_t* header; - ulint n; - bool success; - - if (flst_get_len(space_header + FSP_SEG_HDRS_FREE, mtr) == 0) { - /* Allocate a new segment header page */ - - success = fsp_alloc_seg_hdr_page(space_header, mtr); - - if (!success) { - - return(NULL); - } - } - - page_no = flst_get_first(space_header + FSP_SEG_HDRS_FREE, mtr).page; - - block = buf_page_get(buf_frame_get_space(space_header), page_no, mtr); - - buf_page_x_lock(block, mtr); - - page = buf_block_get_frame(block); - - n = fsp_seg_hdr_page_find_free(page, 0, mtr); - - ut_a(n != ULINT_UNDEFINED); - - header = fsp_seg_hdr_page_get_nth_hdr(page, n, mtr); - - if (ULINT_UNDEFINED == fsp_seg_hdr_page_find_free(page, n + 1, mtr)) { - - /* There are no other unused headers left on the page: move it - to another list */ - - flst_remove(space_header + FSP_SEG_HDRS_FREE, - page + FSEG_HDR_PAGE_NODE, mtr); - - flst_add_last(space_header + FSP_SEG_HDRS_FULL, - page + FSEG_HDR_PAGE_NODE, mtr); - } - - return(header); -} - -/************************************************************************** -Frees a file segment header. */ -static -void -fsp_free_seg_header( -/*================*/ - ulint space, /* in: space id */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mini-transaction handle */ -{ - page_t* page; - fsp_header_t* space_header; - - page = buf_frame_align(header); - - space_header = fsp_get_space_header(space, mtr); - - ut_ad(mach_read_from_4(header + FSEG_MAGIC_N) == FSEG_MAGIC_N_VALUE); - - if (ULINT_UNDEFINED == fsp_seg_hdr_page_find_free(page, mtr)) { - - /* Move the page to another list */ - - flst_remove(space_header + FSP_SEG_HDRS_FULL, - page + FSEG_HDR_PAGE_NODE, mtr); - - flst_add_last(space_header + FSP_SEG_HDRS_FREE, - page + FSEG_HDR_PAGE_NODE, mtr); - } - - mlog_write_dulint(header + FSEG_ID, ut_dulint_zero, MLOG_8BYTES, mtr); - mlog_write_ulint(header + FSEG_MAGIC_N, 0, MLOG_4BYTES, mtr); - - if (ULINT_UNDEFINED == fsp_seg_hdr_page_find_used(page, mtr)) { - - /* There are no other used headers left on the page: free it */ - - flst_remove(space_header + FSP_SEG_HDRS_FREE, - page + FSEG_HDR_PAGE_NODE, mtr); - - fsp_free_page(space, page_no, mtr); - } -} - -/************************************************************************** -Gets the page number from the nth fragment page slot. */ -UNIV_INLINE -ulint -fseg_get_nth_frag_page_no( -/*======================*/ - /* out: page number, FIL_NULL if not in use */ - fseg_header_t* header, /* in: segment header */ - ulint n, /* in: slot index */ - mtr_t* mtr) /* in: mtr handle */ -{ - ut_ad(header && mtr); - ut_ad(n < FSEG_FRAG_ARR_N_SLOTS); - ut_ad(mtr_memo_contains(mtr, buf_block_align(header), - MTR_MEMO_PAGE_X_LOCK)); - - return(mach_read_from_4(header + FSEG_FRAG_ARR - + n * FSEG_FRAG_SLOT_SIZE)); -} - -/************************************************************************** -Sets the page number in the nth fragment page slot. */ -UNIV_INLINE -void -fseg_set_nth_frag_page_no( -/*======================*/ - fseg_header_t* header, /* in: segment header */ - ulint n, /* in: slot index */ - ulint page_no,/* in: page number to set */ - mtr_t* mtr) /* in: mtr handle */ -{ - ut_ad(header && mtr); - ut_ad(n < FSEG_FRAG_ARR_N_SLOTS); - ut_ad(mtr_memo_contains(mtr, buf_block_align(header), - MTR_MEMO_PAGE_X_LOCK)); - - mlog_write_ulint(header + FSEG_FRAG_ARR + n * FSEG_FRAG_SLOT_SIZE, - page_no, MLOG_4BYTES, mtr); -} - -/************************************************************************** -Finds a fragment page slot which is free. */ -static -ulint -fseg_find_free_frag_page_slot( -/*==========================*/ - /* out: slot index; ULINT_UNDEFINED if none - found */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr handle */ -{ - ulint i; - ulint page_no; - - ut_ad(header && mtr); - - for (i = 0; i < FSEG_FRAG_ARR_N_SLOTS; i++) { - page_no = fseg_get_nth_frag_page_no(header, i, mtr); - - if (page_no == FIL_NULL) { - - return(i); - } - } - return(ULINT_UNDEFINED); -} - -/************************************************************************** -Finds a fragment page slot which is used and last in the array. */ -static -ulint -fseg_find_last_used_frag_page_slot( -/*===============================*/ - /* out: slot index; ULINT_UNDEFINED if none - found */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr handle */ -{ - ulint i; - ulint page_no; - - ut_ad(header && mtr); - - for (i = 0; i < FSEG_FRAG_ARR_N_SLOTS; i++) { - page_no = fseg_get_nth_frag_page_no(header, - FSEG_ARR_N_SLOTS - i - 1, mtr); - - if (page_no != FIL_NULL) { - - return(i); - } - } - return(ULINT_UNDEFINED); -} - -/************************************************************************** -Calculates reserved fragment page slots. */ -static -ulint -fseg_get_n_frag_pages( -/*==================*/ - /* out: number of fragment pages */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr handle */ -{ - ulint i; - ulint count = 0; - - ut_ad(header && mtr); - - for (i = 0; i < FSEG_FRAG_ARR_N_SLOTS; i++) { - if (FIL_NULL != fseg_get_nth_frag_page_no(header, i, mtr)) { - count++; - } - } - return(count); -} - -/************************************************************************** -Creates a new segment. */ - -ulint -fseg_create( -/*========*/ - /* out: the page number where the segment header is - placed, FIL_NULL if could not create segment because - lack of space */ - ulint space, /* in: space id */ - ulint* offset, /* out: byte offset of the segment header on its - page */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - buf_frame_t* frame; - fsp_header_t* space_header; - fseg_header_t* header; - dulint seg_id; - ulint i; - - ut_ad(mtr); - - mtr_x_lock(&fsp_latch, mtr); - - space_header = fsp_get_space_header(space, mtr); - - header = fsp_alloc_seg_header(space_header, mtr); - - if (header == NULL) { - - return(FIL_NULL); - } - - /* Read the next segment id from space header and increment the - value in space header */ - - seg_id = mtr_read_dulint(space_header + FSP_SEG_ID, MLOG_8BYTES, mtr); - - mlog_write_dulint(space_header + FSP_SEG_ID, ut_dulint_add(seg_id, 1), - MLOG_8BYTES, mtr); - - mlog_write_dulint(header + FSEG_ID, seg_id, MLOG_8BYTES, mtr); - mlog_write_ulint(header + FSEG_NOT_FULL_N_USED, 0, MLOG_4BYTES, mtr); - - flst_init(header + FSEG_FREE, mtr); - flst_init(header + FSEG_NOT_FULL, mtr); - flst_init(header + FSEG_FULL, mtr); - - mlog_write_ulint(header + FSEG_MAGIC_N, FSEG_MAGIC_N_VALUE, - MLOG_4BYTES, mtr); - for (i = 0; i < FSEG_FRAG_ARR_N_SLOTS; i++) { - fseg_set_nth_frag_page_no(header, i, FIL_NULL, mtr); - } - - *offset = header - buf_frame_align(header); - return(buf_frame_get_page(buf_frame_align(header))); -} - -/************************************************************************** -Calculates the number of pages reserved by a segment, and how -many pages are currently used. */ - -ulint -fseg_n_reserved_pages( -/*==================*/ - /* out: number of reserved pages */ - fseg_header_t* header, /* in: segment header */ - ulint* used, /* out: number of pages used (<= reserved) */ - mtr_t* mtr) /* in: mtr handle */ -{ - ulint ret; - - mtr_x_lock(&fsp_latch, mtr); - - ret = fseg_n_reserved_pages_low(header, used, mtr); - - return(ret); -} - -/************************************************************************** -Calculates the number of pages reserved by a segment, and how -many pages are currently used. */ -static -ulint -fseg_n_reserved_pages_low( -/*======================*/ - /* out: number of reserved pages */ - fseg_header_t* header, /* in: segment header */ - ulint* used, /* out: number of pages used (<= reserved) */ - mtr_t* mtr) /* in: mtr handle */ -{ - ulint ret; - - ut_ad(header && used && mtr); - ut_ad(mtr_memo_contains(mtr, buf_block_align(header), - MTR_MEMO_BUF_FIX)); - - buf_page_x_lock(buf_block_align(header), mtr); - - *used = mtr_read_ulint(header + FSEG_NOT_FULL_N_USED, MLOG_4BYTES, mtr) - + FSP_EXTENT_SIZE * flst_get_len(header + FSEG_FULL, mtr) - + fseg_get_n_frag_pages(header, mtr); - - ret = fseg_get_n_frag_pages(header, mtr) - + FSP_EXTENT_SIZE * flst_get_len(header + FSEG_FREE, mtr) - + FSP_EXTENT_SIZE * flst_get_len(header + FSEG_NOT_FULL, mtr) - + FSP_EXTENT_SIZE * flst_get_len(header + FSEG_FULL, mtr); - - return(ret); -} - -/************************************************************************* -Tries to fill the free list of a segment with consecutive free extents. -This happens if the segment is big enough to allowextents in the free list, -the free list is empty, and the extents can be allocated consecutively from -the hint onward. */ -static -void -fseg_fill_free_list( -/*================*/ - fseg_header_t* header, /* in: segment header */ - ulint space, /* in: space id */ - ulint hint, /* in: hint which extent would be good as - the first extent */ - mtr_t* mtr) /* in: mtr */ -{ - xdes_t* descr; - ulint i; - dulint seg_id; - ulint reserved; - ulint used; - - ut_ad(header && mtr); - - buf_page_x_lock(buf_block_align(header), mtr); - - reserved = fseg_n_reserved_pages_low(header, &used, mtr); - - if (reserved < FSEG_FREE_LIST_LIMIT * FSP_EXTENT_SIZE) { - /* The segment is too small to allow extents in free list */ - - return; - } - - if (flst_get_len(header + FSEG_FREE, mtr) > 0) { - /* Free list is not empty */ - - return; - } - - for (i = 0; i < FSEG_FREE_LIST_MAX_LEN; i++) { - descr = xdes_get_descriptor(space, hint, mtr); - - if ((descr == NULL) || - (XDES_FREE != xdes_get_state(descr, mtr))) { - /* We cannot allocate the desired extent: stop */ - - return; - } - - descr = fsp_alloc_free_extent(space, hint, mtr); - - xdes_set_state(descr, XDES_FSEG, mtr); - - seg_id = mtr_read_dulint(header + FSEG_ID, MLOG_8BYTES, mtr); - mlog_write_dulint(descr + XDES_ID, seg_id, MLOG_8BYTES, mtr); - - flst_add_last(header + FSEG_FREE, descr + XDES_FLST_NODE, mtr); - hint += FSP_EXTENT_SIZE; - } -} - -/************************************************************************* -Allocates a free extent for the segment: looks first in the -free list of the segment, then tries to allocate from the space free -list. NOTE that the extent returned is still placed in the segment free -list, not taken off it! */ -static -xdes_t* -fseg_alloc_free_extent( -/*===================*/ - /* out: allocated extent, still placed in the - segment free list, NULL if could - not be allocated */ - fseg_header_t* header, /* in: segment header */ - ulint space, /* in: space id */ - mtr_t* mtr) /* in: mtr */ -{ - xdes_t* descr; - dulint seg_id; - fil_addr_t first; - - buf_page_x_lock(buf_block_align(header), mtr); - - if (flst_get_len(header + FSEG_FREE, mtr) > 0) { - /* Segment free list is not empty, allocate from it */ - - first = flst_get_first(header + FSEG_FREE, mtr); - - descr = xdes_lst_get_descriptor(space, first, mtr); - } else { - /* Segment free list was empty, allocate from space */ - descr = fsp_alloc_free_extent(space, 0, mtr); - - if (descr == NULL) { - return(NULL); - } - - seg_id = mtr_read_dulint(header + FSEG_ID, MLOG_8BYTES, mtr); - - xdes_set_state(descr, XDES_FSEG, mtr); - mlog_write_dulint(descr + XDES_ID, seg_id, MLOG_8BYTES, mtr); - flst_add_last(header + FSEG_FREE, - descr + XDES_FLST_NODE, mtr); - - /* Try to fill the segment free list */ - fseg_fill_free_list(header, space, - xdes_get_offset(descr) + FSP_EXTENT_SIZE, mtr); - } - - return(descr); -} - -/************************************************************************** -Allocates a single free page from a segment. This function implements -the intelligent allocation strategy which tries to minimize file space -fragmentation. */ - -ulint -fseg_alloc_free_page( -/*=================*/ - /* out: the allocated page offset - FIL_NULL if no page could be allocated */ - fseg_header_t* seg_header, /* in: segment header */ - ulint hint, /* in: hint of which page would be desirable */ - byte direction, /* in: if the new page is needed because - of an index page split, and records are - inserted there in order, into which - direction they go alphabetically: FSP_DOWN, - FSP_UP, FSP_NO_DIR */ - mtr_t* mtr) /* in: mtr handle */ -{ - buf_block_t* block; - dulint seg_id; - fseg_page_header_t* page_header; - ulint space; - ulint used; - ulint reserved; - fil_addr_t first; - xdes_t* descr; /* extent of the hinted page */ - ulint ret_page; /* the allocated page offset, FIL_NULL - if could not be allocated */ - buf_block_t* ret_buf_page; - buf_frame_t* ret_frame; - xdes_t* ret_descr; /* the extent of the allocated page */ - ulint n; - bool frag_page_allocated = FALSE; - - ut_ad(seg_header && mtr); - ut_ad((direction >= FSP_UP) && (direction <= FSP_NO_DIR)); - - mtr_x_lock(&fsp_latch, mtr); - - block = buf_block_align(seg_header); - buf_page_x_lock(block, mtr); - - space = buf_page_get_space(block); - - seg_id = mtr_read_dulint(seg_header + FSEG_ID, MLOG_8BYTES, mtr); - - ut_ad(ut_dulint_cmp(seg_id, ut_dulint_zero) > 0); - - reserved = fseg_n_reserved_pages_low(seg_header, &used, mtr); - - descr = xdes_get_descriptor(space, hint, mtr); - - if (descr == NULL) { - /* Hint outside space or too high above free limit: - reset hint */ - hint = 0; - descr = xdes_get_descriptor(space, hint, mtr); - } - - /* In the big if-else below we look for ret_page and ret_descr */ - /*-------------------------------------------------------------*/ - if ((xdes_get_state(descr, mtr) == XDES_FSEG) - && (0 == ut_dulint_cmp(mtr_read_dulint(descr + XDES_ID, - MLOG_8BYTES, mtr), - seg_id)) - && (xdes_get_bit(descr, XDES_FREE_BIT, - hint % FSP_EXTENT_SIZE, mtr) == TRUE)) { - - /* 1. We can take the hinted page - =================================*/ - ret_descr = descr; - ret_page = hint; - /*-------------------------------------------------------------*/ - } else if ((xdes_get_state(descr, mtr) == XDES_FREE) - && ((reserved - used) < reserved / FSEG_FILLFACTOR) - && (used >= FSEG_FRAG_LIMIT)) { - - /* 2. We allocate the free extent from space and can take - ========================================================= - the hinted page - ===============*/ - ret_descr = fsp_alloc_free_extent(space, hint, mtr); - - ut_a(ret_descr == descr); - - xdes_set_state(ret_descr, XDES_FSEG, mtr); - mlog_write_dulint(ret_descr + XDES_ID, seg_id, MLOG_8BYTES, - mtr); - flst_add_last(seg_header + FSEG_FREE, - ret_descr + XDES_FLST_NODE, mtr); - - /* Try to fill the segment free list */ - fseg_fill_free_list(seg_header, space, - hint + FSP_EXTENT_SIZE, mtr); - ret_page = hint; - /*-------------------------------------------------------------*/ - } else if ((direction != FSP_NO_DIR) - && ((reserved - used) < reserved / FSEG_FILLFACTOR) - && (used >= FSEG_FRAG_LIMIT) - && (NULL != (ret_descr = - fseg_alloc_free_extent(seg_header, space, mtr)))) { - - /* 3. We take any free extent (which was already assigned above - =============================================================== - in the if-condition to ret_descr) and take the lowest or - ======================================================== - highest page in it, depending on the direction - ==============================================*/ - ret_page = xdes_get_offset(ret_descr); - if (direction == FSP_DOWN) { - ret_page += FSP_EXTENT_SIZE - 1; - } - /*-------------------------------------------------------------*/ - } else if ((xdes_get_state(descr, mtr) == XDES_FSEG) - && (0 == ut_dulint_cmp(mtr_read_dulint(descr + XDES_ID, - MLOG_8BYTES, mtr), - seg_id)) - && (!xdes_is_full(descr, mtr))) { - - /* 4. We can take the page from the same extent as the - ====================================================== - hinted page (and the extent already belongs to the - ================================================== - segment) - ========*/ - ret_descr = descr; - ret_page = xdes_get_offset(ret_descr) + - xdes_find_bit(ret_descr, XDES_FREE_BIT, TRUE, - hint % FSP_EXTENT_SIZE, mtr); - /*-------------------------------------------------------------*/ - } else if (reserved - used > 0) { - /* 5. We take any unused page from the segment - ==============================================*/ - if (flst_get_len(seg_header + FSEG_NOT_FULL, mtr) > 0) { - first = flst_get_first(seg_header + FSEG_NOT_FULL, - mtr); - } else if (flst_get_len(seg_header + FSEG_FREE, mtr) > 0) { - first = flst_get_first(seg_header + FSEG_FREE, mtr); - } else { - ut_error; - } - - ret_descr = xdes_lst_get_descriptor(space, first, mtr); - ret_page = xdes_get_offset(ret_descr) + - xdes_find_bit(ret_descr, XDES_FREE_BIT, TRUE, - 0, mtr); - /*-------------------------------------------------------------*/ - } else if (used < FSEG_FRAG_LIMIT) { - /* 6. We allocate an individual page from the space - ===================================================*/ - ret_page = fsp_alloc_free_page(space, hint, mtr); - ret_descr = NULL; - - frag_page_allocated = TRUE; - - if (ret_page != FIL_NULL) { - /* Put the page in the fragment page array of the - segment */ - n = fseg_find_free_frag_page_slot(seg_header, mtr); - ut_a(n != FIL_NULL); - - fseg_set_nth_frag_page_no(seg_header, n, ret_page, - mtr); - } - /*-------------------------------------------------------------*/ - } else { - /* 7. We allocate a new extent and take its first page - ======================================================*/ - ret_descr = fseg_alloc_free_extent(seg_header, space, mtr); - - if (ret_descr == NULL) { - ret_page = FIL_NULL; - } else { - ret_page = xdes_get_offset(ret_descr); - } - } - - if (ret_page == FIL_NULL) { - /* Page could not be allocated */ - - return(FIL_NULL); - } - - /* Initialize the allocated page to buffer pool, so that it can be - obtained immediately with buf_page_get without need for disk read */ - - ret_buf_page = buf_page_create(space, ret_page, mtr); - - if (!frag_page_allocated) { - /* At this point we know the extent and the page offset. - The extent is still in the appropriate list (FSEG_NOT_FULL or - FSEG_FREE), and the page is not yet marked as used. */ - - ut_ad(xdes_get_descriptor(space, ret_page, mtr) == ret_descr); - ut_ad(xdes_get_bit(ret_descr, XDES_FREE_BIT, - ret_page % FSP_EXTENT_SIZE, mtr) == TRUE); - - fseg_mark_page_used(seg_header, space, ret_page, mtr); - } - - return(ret_page); -} - -/************************************************************************ -Marks a page used. The page must reside within the extents of the given -segment. */ -static -void -fseg_mark_page_used( -/*================*/ - fseg_header_t* seg_header,/* in: segment header */ - ulint space, /* in: space id */ - ulint page, /* in: page offset */ - mtr_t* mtr) /* in: mtr */ -{ - xdes_t* descr; - ulint not_full_n_used; - - ut_ad(seg_header && mtr); - - descr = xdes_get_descriptor(space, page, mtr); - - ut_ad(mtr_read_ulint(seg_header + FSEG_ID, MLOG_4BYTES, mtr) == - mtr_read_ulint(descr + XDES_ID, MLOG_4BYTES, mtr)); - - if (xdes_is_free(descr, mtr)) { - /* We move the extent from the free list to the - NOT_FULL list */ - flst_remove(seg_header + FSEG_FREE, - descr + XDES_FLST_NODE, mtr); - flst_add_last(seg_header + FSEG_NOT_FULL, - descr + XDES_FLST_NODE, mtr); - } - - ut_ad(xdes_get_bit(descr, XDES_FREE_BIT, page % FSP_EXTENT_SIZE, mtr) - == TRUE); - - /* We mark the page as used */ - xdes_set_bit(descr, XDES_FREE_BIT, page % FSP_EXTENT_SIZE, FALSE, mtr); - - not_full_n_used = mtr_read_ulint(seg_header + FSEG_NOT_FULL_N_USED, - MLOG_4BYTES, mtr); - - not_full_n_used++; - mlog_write_ulint(seg_header + FSEG_NOT_FULL_N_USED, - not_full_n_used, MLOG_4BYTES, mtr); - - if (xdes_is_full(descr, mtr)) { - /* We move the extent from the NOT_FULL list to the - FULL list */ - flst_remove(seg_header + FSEG_NOT_FULL, - descr + XDES_FLST_NODE, mtr); - flst_add_last(seg_header + FSEG_FULL, - descr + XDES_FLST_NODE, mtr); - - mlog_write_ulint(seg_header + FSEG_NOT_FULL_N_USED, - not_full_n_used - FSP_EXTENT_SIZE, - MLOG_4BYTES, mtr); - } -} - -/************************************************************************** -Frees a single page of a segment. */ - -void -fseg_free_page( -/*===========*/ - fseg_header_t* seg_header, /* in: segment header */ - ulint space, /* in: space id */ - ulint page, /* in: page offset */ - mtr_t* mtr) /* in: mtr handle */ -{ - mtr_x_lock(&fsp_latch, mtr); - - fseg_free_page_low(seg_header, space, page, mtr); -} - -/************************************************************************** -Frees a single page of a segment. */ -static -void -fseg_free_page_low( -/*===============*/ - fseg_header_t* seg_header, /* in: segment header */ - ulint space, /* in: space id */ - ulint page, /* in: page offset */ - mtr_t* mtr) /* in: mtr handle */ -{ - buf_block_t* block; - xdes_t* descr; - ulint used; - ulint not_full_n_used; - ulint state; - buf_block_t* buf_page; - buf_frame_t* buf_frame; - ulint i; - - ut_ad(seg_header && mtr); - - block = buf_block_align(seg_header); - buf_page_x_lock(block, mtr); - - descr = xdes_get_descriptor(space, page, mtr); - - ut_a(descr); - ut_a(xdes_get_bit(descr, XDES_FREE_BIT, page % FSP_EXTENT_SIZE, mtr) - == FALSE); - - state = xdes_get_state(descr, mtr); - - if (state != XDES_FSEG) { - /* The page is in the fragment pages of the segment */ - - for (i = 0;; i++) { - if (fseg_get_nth_frag_page_no(seg_header, i, mtr) - == page) { - - fseg_set_nth_frag_page_no(seg_header, i, - FIL_NULL, mtr); - break; - } - } - - fsp_free_page(space, page, mtr); - - return; - } - - /* If we get here, the page is in some extent of the segment */ - ut_a(0 == ut_dulint_cmp( - mtr_read_dulint(descr + XDES_ID, MLOG_8BYTES, mtr), - mtr_read_dulint(seg_header + FSEG_ID, MLOG_8BYTES, mtr))); - - not_full_n_used = mtr_read_ulint(seg_header + FSEG_NOT_FULL_N_USED, - MLOG_4BYTES, mtr); - if (xdes_is_full(descr, mtr)) { - /* The fragment is full: move it to another list */ - flst_remove(seg_header + FSEG_FULL, - descr + XDES_FLST_NODE, mtr); - flst_add_last(seg_header + FSEG_NOT_FULL, - descr + XDES_FLST_NODE, mtr); - mlog_write_ulint(seg_header + FSEG_NOT_FULL_N_USED, - not_full_n_used + FSP_EXTENT_SIZE - 1, - MLOG_4BYTES, mtr); - } else { - ut_a(not_full_n_used > 0); - mlog_write_ulint(seg_header + FSEG_NOT_FULL_N_USED, - not_full_n_used - 1, - MLOG_4BYTES, mtr); - } - - xdes_set_bit(descr, XDES_FREE_BIT, page % FSP_EXTENT_SIZE, TRUE, mtr); - xdes_set_bit(descr, XDES_CLEAN_BIT, page % FSP_EXTENT_SIZE, TRUE, mtr); - - if (xdes_is_free(descr, mtr)) { - /* The extent has become free: free it to space */ - flst_remove(seg_header + FSEG_NOT_FULL, - descr + XDES_FLST_NODE, mtr); - fsp_free_extent(space, page, mtr); - } -} - -/************************************************************************** -Frees an extent of a segment to the space free list. */ -static -void -fseg_free_extent( -/*=============*/ - fseg_header_t* seg_header, /* in: segment header */ - ulint space, /* in: space id */ - ulint page, /* in: page offset in the extent */ - mtr_t* mtr) /* in: mtr handle */ -{ - buf_block_t* block; - xdes_t* descr; - ulint not_full_n_used; - ulint descr_n_used; - - ut_ad(seg_header && mtr); - - block = buf_block_align(seg_header); - buf_page_x_lock(block, mtr); - - descr = xdes_get_descriptor(space, page, mtr); - - ut_a(xdes_get_state(descr, mtr) == XDES_FSEG); - ut_a(0 == ut_dulint_cmp( - mtr_read_dulint(descr + XDES_ID, MLOG_8BYTES, mtr), - mtr_read_dulint(seg_header + FSEG_ID, MLOG_8BYTES, mtr))); - - if (xdes_is_full(descr, mtr)) { - flst_remove(seg_header + FSEG_FULL, - descr + XDES_FLST_NODE, mtr); - } else if (xdes_is_free(descr, mtr)) { - flst_remove(seg_header + FSEG_FREE, - descr + XDES_FLST_NODE, mtr); - } else { - flst_remove(seg_header + FSEG_NOT_FULL, - descr + XDES_FLST_NODE, mtr); - - not_full_n_used = mtr_read_ulint( - seg_header + FSEG_NOT_FULL_N_USED, - MLOG_4BYTES, mtr); - - descr_n_used = xdes_get_n_used(descr, mtr); - ut_a(not_full_n_used >= descr_n_used); - mlog_write_ulint(seg_header + FSEG_NOT_FULL_N_USED, - not_full_n_used - descr_n_used, - MLOG_4BYTES, mtr); - } - fsp_free_extent(space, page, mtr); -} - -/************************************************************************** -Frees part of a segment. This function can be used to free a segment -by repeatedly calling this function in different mini-transactions. -Doing the freeing in a single mini-transaction might result in too big -a mini-transaction. */ - -bool -fseg_free_step( -/*===========*/ - /* out: TRUE if freeing completed */ - ulint space, /* in: segment space id */ - ulint page_no,/* in: segment header page number */ - ulint offset, /* in: segment header byte offset on page */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - ulint n; - ulint page; - xdes_t* descr; - fseg_header_t* header; - fil_addr_t header_addr; - - header_addr.page = page_no; - header_addr.boffset = offset; - - mtr_x_lock(&fsp_latch, mtr); - - header = fut_get_ptr_x_lock(space, header_addr, mtr); - - descr = fseg_get_first_extent(header, mtr); - - if (descr != NULL) { - /* Free the extent held by the segment */ - page = xdes_get_offset(descr); - - fseg_free_extent(header, space, page, mtr); - - return(FALSE); - } - - /* Free a frag page */ - - n = fseg_get_last_used_frag_page_slot(header, mtr); - - if (n == ULINT_UNDEFINED) { - /* Freeing completed: free the segment header */ - fsp_free_seg_header(space, header, mtr); - - return(TRUE); - } - - fseg_free_page_low(header, space, - fseg_get_nth_frag_page_no(header, n, mtr), mtr); - - return(FALSE); -} - -/*********************************************************************** -Frees a segment. The freeing is performed in several mini-transactions, -so that there is no danger of bufferfixing too many buffer pages. */ - -void -fseg_free( -/*======*/ - ulint space, /* in: space id */ - ulint page_no,/* in: page number where the segment header is - placed */ - ulint offset) /* in: byte offset of the segment header on that - page */ -{ - mtr_t mtr; - buf_block_t* block; - bool finished; - - for (;;) { - mtr_start(&mtr); - - block = buf_page_get(space, page_no, &mtr); - - finished = fseg_free_step(space, page_no, offset, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - } -} - -/************************************************************************** -Returns the first extent descriptor for a segment. We think of the extent -lists of the segment catenated in the order FSEG_FULL -> FSEG_NOT_FULL --> FSEG_FREE. */ -static -xdes_t* -fseg_get_first_extent( -/*==================*/ - /* out: the first extent descriptor, or NULL if - none */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - fil_addr_t first; - ulint space; - xdes_t* descr; - - ut_ad(header && mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - space = buf_page_get_space(block); - - first = fil_addr_null; - - if (flst_get_len(header + FSEG_FULL, mtr) > 0) { - first = flst_get_first(header + FSEG_FULL, mtr); - } else if (flst_get_len(header + FSEG_NOT_FULL, mtr) > 0) { - first = flst_get_first(header + FSEG_NOT_FULL, mtr); - } else if (flst_get_len(header + FSEG_FREE, mtr) > 0) { - first = flst_get_first(header + FSEG_FREE, mtr); - } - - if (first.page == FIL_NULL) { - return(NULL); - } else { - descr = xdes_lst_get_descriptor(space, first, mtr); - return(descr); - } -} - -#ifdef notdefined - -/************************************************************************** -Returns the last non-free extent descriptor for a segment. We think of -the extent lists of the segment catenated in the order FSEG_FULL -> -FSEG_NOT_FULL -> FSEG_FREE. */ -static -xdes_t* -fseg_get_last_non_free_extent( -/*==========================*/ - /* out: the last extent descriptor, or NULL if - none */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - fil_addr_t last; - ulint space; - xdes_t* descr; - - ut_ad(header && mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - space = buf_page_get_space(block); - - last = fil_addr_null; - - if (flst_get_len(header + FSEG_NOT_FULL, mtr) > 0) { - last = flst_get_last(header + FSEG_NOT_FULL, mtr); - } else if (flst_get_len(header + FSEG_FULL, mtr) > 0) { - last = flst_get_last(header + FSEG_FULL, mtr); - } - - if (last.page == FIL_NULL) { - return(NULL); - } else { - descr = xdes_lst_get_descriptor(space, last, mtr); - return(descr); - } -} - -/************************************************************************** -Returns the next extent descriptor for a segment. We think of the extent -lists of the segment catenated in the order FSEG_FULL -> FSEG_NOT_FULL --> FSEG_FREE. */ -static -xdes_t* -fseg_get_next_extent( -/*=================*/ - /* out: next extent descriptor, or NULL if - none */ - fseg_header_t* header, /* in: segment header */ - xdes_t* descr, /* in: previous extent descriptor */ - mtr_t* mtr) /* in: mtr */ -{ - fil_addr_t next_addr; - buf_block_t* block; - ulint space; - - ut_ad(header && descr && mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - space = buf_page_get_space(block); - - next_addr = flst_get_next_addr(descr + XDES_FLST_NODE, mtr); - - if (next_addr.page == FIL_NULL) { - /* This is the last extent in the list. */ - if (xdes_is_full(descr, mtr)) { - /* descr is in FSEG_FULL list */ - if (flst_get_len(header + FSEG_NOT_FULL, mtr) > 0) { - next_addr = flst_get_first(header - + FSEG_NOT_FULL, mtr); - } else if (flst_get_len(header + FSEG_FREE, mtr) > 0) { - next_addr = flst_get_first(header - + FSEG_FREE, mtr); - } - } else if (!xdes_is_full(descr, mtr) - && !xdes_is_free(descr, mtr)) { - /* descr is in FSEG_NOT_FULL list */ - if (flst_get_len(header + FSEG_FREE, mtr) > 0) { - next_addr = flst_get_first(header - + FSEG_FREE, mtr); - } - } - } - - if (next_addr.page != FIL_NULL) { - descr = xdes_lst_get_descriptor(space, next_addr, mtr); - ut_ad(descr); - return(descr); - } else { - return(NULL); - } -} - -/************************************************************************** -Returns the previous extent descriptor for a segment. We think of the extent -lists of the segment catenated in the order FSEG_FULL -> FSEG_NOT_FULL --> FSEG_FREE. */ -static -xdes_t* -fseg_get_prev_extent( -/*=================*/ - /* out: previous extent descriptor, or NULL if - none */ - fseg_header_t* header, /* in: segment header */ - xdes_t* descr, /* in: extent descriptor */ - mtr_t* mtr) /* in: mtr */ -{ - fil_addr_t prev_addr; - buf_block_t* block; - ulint space; - - ut_ad(header && descr && mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - space = buf_page_get_space(block); - - prev_addr = flst_get_prev_addr(descr + XDES_FLST_NODE, mtr); - - if (prev_addr.page == FIL_NULL) { - /* This is the first extent in the list. */ - if (xdes_is_free(descr, mtr)) { - /* descr is in FSEG_FREE list */ - if (flst_get_len(header + FSEG_NOT_FULL, mtr) > 0) { - prev_addr = flst_get_last(header - + FSEG_NOT_FULL, mtr); - } else if (flst_get_len(header + FSEG_FULL, mtr) > 0) { - prev_addr = flst_get_last(header - + FSEG_FULL, mtr); - } - } else if (!xdes_is_full(descr, mtr) - && !xdes_is_free(descr, mtr)) { - /* descr is in FSEG_NOT_FULL list */ - if (flst_get_len(header + FSEG_FULL, mtr) > 0) { - prev_addr = flst_get_last(header - + FSEG_FULL, mtr); - } - } - } - - if (prev_addr.page != FIL_NULL) { - descr = xdes_lst_get_descriptor(space, prev_addr, mtr); - ut_ad(descr); - return(descr); - } else { - return(NULL); - } -} - -/************************************************************************* -Gets the first used page number in the given extent assigned to a -specific segment, or its successors, in the order defined in -fsp_get_next_extent. */ -static -ulint -fseg_extent_get_next_page_no( -/*=========================*/ - /* next used page number in the given extent - or a successor of it, FIL_NULL if no page - found */ - fseg_header_t* header, /* in: segment header */ - xdes_t* descr, /* in: extent descriptor, if this is NULL, the - function returns FIL_NULL */ - mtr_t* mtr) /* in: mtr */ -{ - ulint bit; - - UT_NOT_USED(header); - ut_ad((descr == NULL) || (xdes_get_state(descr, mtr) == XDES_FSEG)); - - for (;;) { - if (descr == NULL) { - return(FIL_NULL); - } - - bit = xdes_find_bit(descr, XDES_FREE_BIT, FALSE, 0, mtr); - - if (bit == ULINT_UNDEFINED) { - /* No page found in this extent: the extent is in - FSEG_FREE list, thus, no used page can be found - in successors */ - return(FIL_NULL); - } else { - return(xdes_get_offset(descr) + bit); - } - } -} - -/************************************************************************* -Gets the last used page number in the given extent assigned to a -specific segment, or its predecessor extents, in the order defined in -fsp_get_next_extent. If the page cannot be found from the extents, -the last page of the fragment list is returned, or FIL_NULL if it is -empty.*/ -static -ulint -fseg_extent_get_prev_page_no( -/*=========================*/ - /* previous used page number in the given - extent or a predecessor, FIL_NULL - if no page found */ - fseg_header_t* header, /* in: segment header */ - xdes_t* descr, /* in: extent descriptor, if this is NULL, the - function returns the last page of the fragment - list, if any */ - mtr_t* mtr) /* in: mtr */ -{ - ulint prev_page_no; - ulint bit; - fil_addr_t last_frag_page_addr; - - ut_ad((descr == NULL) || (xdes_get_state(descr, mtr) == XDES_FSEG)); - - for (;;) { - if (descr == NULL) { - prev_page_no = FIL_NULL; - break; - } - - bit = xdes_find_bit_downward(descr, XDES_FREE_BIT, FALSE, - FSP_EXTENT_SIZE - 1, mtr); - - if (bit == ULINT_UNDEFINED) { - descr = fseg_get_prev_extent(header, descr, mtr); - } else { - prev_page_no = xdes_get_offset(descr) + bit; - break; - } - } - - if (prev_page_no == FIL_NULL) { - last_frag_page_addr = flst_get_last(header + FSEG_FRAG, mtr); - prev_page_no = last_frag_page_addr.page; - } - - return(prev_page_no); -} - -/************************************************************************** -Returns the page number of the first segment page. If no pages have been -freed from the segment, and the pages were allocated with the hint page -number always one greater than previous page, then it is guaranteed that -this function returns the first allocated page. */ - -ulint -fseg_get_first_page_no( -/*===================*/ - /* out: page number, FIL_NULL if no - page found */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - ulint first_page_no; - xdes_t* descr; - fil_addr_t first_frag_page_addr; - - ut_ad(header); - - mtr_x_lock(&fsp_latch, mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - /* Find first page */ - first_frag_page_addr = flst_get_first(header + FSEG_FRAG, mtr); - first_page_no = first_frag_page_addr.page; - - if (first_page_no == FIL_NULL) { - descr = fseg_get_first_extent(header, mtr); - first_page_no = fseg_extent_get_next_page_no(header, descr, - mtr); - } - - return(first_page_no); -} - -/************************************************************************** -Returns the page number of the last segment page. If no pages have been -freed from the segment, and the pages were allocated with the hint page -number always one greater than previous page, then it is guaranteed that -this function returns the last allocated page. */ - -ulint -fseg_get_last_page_no( -/*==================*/ - /* out: page number, FIL_NULL if no - page found */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - ulint last_page_no; - xdes_t* descr; - - ut_ad(header); - - mtr_x_lock(&fsp_latch, mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - descr = fseg_get_last_non_free_extent(header, mtr); - last_page_no = fseg_extent_get_prev_page_no(header, descr, mtr); - - return(last_page_no); -} - -/************************************************************************** -Returns the page number of the next segment page. If no pages have been -freed from the segment, and the pages were allocated with the hint page -number always one greater than previous page, then it is guaranteed that -this function steps the pages through in the order they were allocated -to the segment. */ - -ulint -fseg_get_next_page_no( -/*==================*/ - /* out: page number, FIL_NULL if no - page left */ - fseg_header_t* header, /* in: segment header */ - ulint page_no,/* in: previous page number */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - buf_frame_t* frame; - ulint space; - ulint next_page_no; - xdes_t* descr; - ulint bit; - fil_addr_t next_frag_page_addr; - fseg_page_header_t* page_header; - - ut_ad(header); - - mtr_x_lock(&fsp_latch, mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - space = buf_page_get_space(block); - - descr = xdes_get_descriptor(space, page_no, mtr); - ut_ad(xdes_get_bit(descr, XDES_FREE_BIT, - page_no % FSP_EXTENT_SIZE, mtr) == FALSE); - - if (xdes_get_state(descr, mtr) == XDES_FSEG) { - /* The extent of the current page belongs to the segment */ - bit = xdes_find_bit(descr, XDES_FREE_BIT, FALSE, - (page_no + 1) % FSP_EXTENT_SIZE, - mtr); - if ((bit == ULINT_UNDEFINED) - || (bit <= (page_no % FSP_EXTENT_SIZE))) { - /* No higher address pages in this extent */ - descr = fseg_get_next_extent(header, descr, mtr); - next_page_no = fseg_extent_get_next_page_no( - header, descr, mtr); - } else { - next_page_no = xdes_get_offset(descr) + bit; - } - } else { - /* Current page is a fragment page */ - block = buf_page_get(space, page_no, mtr); - buf_page_x_lock(block, mtr); - frame = buf_block_get_frame(block); - page_header = frame + FSEG_PAGE_HEADER_OFFSET; - next_frag_page_addr = flst_get_next_addr( - page_header + FSEG_PAGE_FRAG_NODE, - mtr); - - next_page_no = next_frag_page_addr.page; - if (next_page_no == FIL_NULL) { - descr = fseg_get_first_extent(header, mtr); - next_page_no = fseg_extent_get_next_page_no( - header, descr, mtr); - } - } - return(next_page_no); -} - -/************************************************************************** -Returns the page number of the previous segment page. If no pages have been -freed from the segment, and the pages were allocated with the hint page -number always one greater than the previous page, then it is guaranteed that -this function steps through the pages in the order opposite to the allocation -order of the pages. */ - -ulint -fseg_get_prev_page_no( -/*==================*/ - /* out: page number, FIL_NULL if no page - left */ - fseg_header_t* header, /* in: segment header */ - ulint page_no,/* in: page number */ - mtr_t* mtr) /* in: mtr */ -{ - buf_block_t* block; - buf_frame_t* frame; - ulint space; - ulint prev_page_no; - xdes_t* descr; - ulint bit; - fil_addr_t prev_frag_page_addr; - fseg_page_header_t* page_header; - - ut_ad(header); - - mtr_x_lock(&fsp_latch, mtr); - - block = buf_block_align(header); - buf_page_x_lock(block, mtr); - - space = buf_page_get_space(block); - - descr = xdes_get_descriptor(space, page_no, mtr); - ut_ad(xdes_get_bit(descr, XDES_FREE_BIT, - page_no % FSP_EXTENT_SIZE, mtr) == FALSE); - - if (xdes_get_state(descr, mtr) == XDES_FSEG) { - /* The extent of the current page belongs to the segment */ - bit = xdes_find_bit_downward(descr, XDES_FREE_BIT, FALSE, - (page_no - 1) % FSP_EXTENT_SIZE, - mtr); - if ((bit == ULINT_UNDEFINED) - || (bit >= (page_no % FSP_EXTENT_SIZE))) { - /* No lower address pages in this extent */ - descr = fseg_get_prev_extent(header, descr, mtr); - prev_page_no = fseg_extent_get_prev_page_no( - header, descr, mtr); - } else { - prev_page_no = xdes_get_offset(descr) + bit; - } - } else { - /* Current page is a fragment page */ - block = buf_page_get(space, page_no, mtr); - buf_page_x_lock(block, mtr); - frame = buf_block_get_frame(block); - page_header = frame + FSEG_PAGE_HEADER_OFFSET; - prev_frag_page_addr = flst_get_prev_addr( - page_header + FSEG_PAGE_FRAG_NODE, - mtr); - - prev_page_no = prev_frag_page_addr.page; - } - return(prev_page_no); -} - -#endif - -/*********************************************************************** -Validates a segment. */ -static -bool -fseg_validate_low( -/*==============*/ - /* out: TRUE if ok */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr2) /* in: mtr */ -{ - ulint space; - dulint seg_id; - mtr_t mtr; - xdes_t* descr; - fil_addr_t node_addr; - ulint n_used = 0; - ulint n_used2 = 0; - flst_node_t* node; - buf_frame_t* frame; - fseg_page_header_t* page_header; - - ut_ad(mtr_memo_contains(mtr2, buf_block_align(header), - MTR_MEMO_BUF_FIX)); - buf_page_x_lock(buf_block_align(header), mtr2); - - space = buf_page_get_space(buf_block_align(header)); - - seg_id = mtr_read_dulint(header + FSEG_ID, MLOG_8BYTES, mtr2); - n_used = mtr_read_ulint(header + FSEG_NOT_FULL_N_USED, - MLOG_4BYTES, mtr2); - - flst_validate(header + FSEG_FRAG, mtr2); - flst_validate(header + FSEG_FREE, mtr2); - flst_validate(header + FSEG_NOT_FULL, mtr2); - flst_validate(header + FSEG_FULL, mtr2); - - /* Validate FSEG_FREE list */ - node_addr = flst_get_first(header + FSEG_FREE, mtr2); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - descr = xdes_lst_get_descriptor(space, node_addr, &mtr); - - ut_a(xdes_get_n_used(descr, &mtr) == 0); - ut_a(xdes_get_state(descr, &mtr) == XDES_FSEG); - ut_a(0 == ut_dulint_cmp( - mtr_read_dulint(descr + XDES_ID, MLOG_8BYTES, - &mtr), seg_id)); - - node_addr = flst_get_next_addr(descr + XDES_FLST_NODE, &mtr); - mtr_commit(&mtr); - } - - /* Validate FSEG_NOT_FULL list */ - - node_addr = flst_get_first(header + FSEG_NOT_FULL, mtr2); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - descr = xdes_lst_get_descriptor(space, node_addr, &mtr); - - ut_a(xdes_get_n_used(descr, &mtr) > 0); - ut_a(xdes_get_n_used(descr, &mtr) < FSP_EXTENT_SIZE); - ut_a(xdes_get_state(descr, &mtr) == XDES_FSEG); - ut_a(0 == ut_dulint_cmp( - mtr_read_dulint(descr + XDES_ID, MLOG_8BYTES, - &mtr), seg_id)); - - n_used2 += xdes_get_n_used(descr, &mtr); - - node_addr = flst_get_next_addr(descr + XDES_FLST_NODE, &mtr); - mtr_commit(&mtr); - } - - /* Validate FSEG_FULL list */ - - node_addr = flst_get_first(header + FSEG_FULL, mtr2); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - descr = xdes_lst_get_descriptor(space, node_addr, &mtr); - - ut_a(xdes_get_n_used(descr, &mtr) == FSP_EXTENT_SIZE); - ut_a(xdes_get_state(descr, &mtr) == XDES_FSEG); - ut_a(0 == ut_dulint_cmp( - mtr_read_dulint(descr + XDES_ID, MLOG_8BYTES, - &mtr), seg_id)); - - node_addr = flst_get_next_addr(descr + XDES_FLST_NODE, &mtr); - mtr_commit(&mtr); - } - - /* Validate FSEG_FRAG list */ - node_addr = flst_get_first(header + FSEG_FRAG, mtr2); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - node = fut_get_ptr_x_lock(space, node_addr, &mtr); - frame = buf_frame_align(node); - page_header = frame + FSEG_PAGE_HEADER_OFFSET; - ut_a(0 == ut_dulint_cmp( - mtr_read_dulint(page_header + FSEG_PAGE_SEG_ID, - MLOG_8BYTES, &mtr), seg_id)); - - node_addr = flst_get_next_addr(node, &mtr); - mtr_commit(&mtr); - } - - ut_a(n_used == n_used2); - - return(TRUE); -} - -/*********************************************************************** -Validates a segment. */ - -bool -fseg_validate( -/*==========*/ - /* out: TRUE if ok */ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr2) /* in: mtr */ -{ - bool ret; - - mtr_x_lock(&fsp_latch, mtr2); - ret = fseg_validate_low(header, mtr2); - - return(ret); -} - -/*********************************************************************** -Writes info of a segment. */ -static -void -fseg_print_low( -/*===========*/ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr */ -{ - ulint space; - ulint seg_id_low; - ulint seg_id_high; - ulint n_used; - ulint n_frag; - ulint n_free; - ulint n_not_full; - ulint n_full; - ulint reserved; - ulint used; - ulint page_no; - - ut_ad(mtr_memo_contains(mtr, buf_block_align(header), - MTR_MEMO_BUF_FIX)); - buf_page_x_lock(buf_block_align(header), mtr); - - space = buf_page_get_space(buf_block_align(header)); - page_no = buf_page_get_offset(buf_block_align(header)); - - reserved = fseg_n_reserved_pages_low(header, &used, mtr); - - seg_id_low = ut_dulint_get_low(mtr_read_dulint(header + FSEG_ID, - MLOG_8BYTES, mtr)); - seg_id_high = ut_dulint_get_high(mtr_read_dulint(header + FSEG_ID, - MLOG_8BYTES, mtr)); - - n_used = mtr_read_ulint(header + FSEG_NOT_FULL_N_USED, - MLOG_4BYTES, mtr); - - n_frag = flst_get_len(header + FSEG_FRAG, mtr); - n_free = flst_get_len(header + FSEG_FREE, mtr); - n_not_full = flst_get_len(header + FSEG_NOT_FULL, mtr); - n_full = flst_get_len(header + FSEG_FULL, mtr); - - printf( - "SEGMENT id %lu %lu space %lu; page %lu; res %lu used %lu; full ext %lu\n", - seg_id_high, seg_id_low, space, page_no, reserved, used, - n_full); - printf( - "fragm pages %lu; free extents %lu; not full extents %lu: pages %lu\n", - n_frag, n_free, n_not_full, n_used); -} - -/*********************************************************************** -Writes info of a segment. */ - -void -fseg_print( -/*=======*/ - fseg_header_t* header, /* in: segment header */ - mtr_t* mtr) /* in: mtr */ -{ - mtr_x_lock(&fsp_latch, mtr); - - fseg_print_low(header, mtr); -} - -/*********************************************************************** -Validates the file space system and its segments. */ - -bool -fsp_validate( -/*=========*/ - /* out: TRUE if ok */ - ulint space) /* in: space id */ -{ - fsp_header_t* header; - fseg_header_t* seg_header; - ulint size; - ulint free_limit; - ulint frag_n_used; - mtr_t mtr; - mtr_t mtr2; - xdes_t* descr; - fil_addr_t node_addr; - ulint descr_count = 0; - ulint n_used = 0; - ulint n_used2 = 0; - ulint n_full_frag_pages; - - /* Start first a mini-transaction mtr2 to lock out all other threads - from the fsp system */ - mtr_start(&mtr2); - mtr_x_lock(&fsp_latch, &mtr2); - - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - header = fsp_get_space_header(space, &mtr); - - size = mtr_read_ulint(header + FSP_SIZE, MLOG_4BYTES, &mtr); - free_limit = mtr_read_ulint(header + FSP_FREE_LIMIT, - MLOG_4BYTES, &mtr); - frag_n_used = mtr_read_ulint(header + FSP_FRAG_N_USED, - MLOG_4BYTES, &mtr); - - n_full_frag_pages = FSP_EXTENT_SIZE * - flst_get_len(header + FSP_FULL_FRAG, &mtr); - - ut_a(free_limit <= size); - - flst_validate(header + FSP_FREE, &mtr); - flst_validate(header + FSP_FREE_FRAG, &mtr); - flst_validate(header + FSP_FULL_FRAG, &mtr); - flst_validate(header + FSP_SEGS, &mtr); - - mtr_commit(&mtr); - - /* Validate FSP_FREE list */ - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - header = fsp_get_space_header(space, &mtr); - node_addr = flst_get_first(header + FSP_FREE, &mtr); - - mtr_commit(&mtr); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - descr_count++; - descr = xdes_lst_get_descriptor(space, node_addr, &mtr); - - ut_a(xdes_get_n_used(descr, &mtr) == 0); - ut_a(xdes_get_state(descr, &mtr) == XDES_FREE); - - node_addr = flst_get_next_addr(descr + XDES_FLST_NODE, &mtr); - mtr_commit(&mtr); - } - - /* Validate FSP_FREE_FRAG list */ - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - header = fsp_get_space_header(space, &mtr); - node_addr = flst_get_first(header + FSP_FREE_FRAG, &mtr); - - mtr_commit(&mtr); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - descr_count++; - descr = xdes_lst_get_descriptor(space, node_addr, &mtr); - - ut_a(xdes_get_n_used(descr, &mtr) > 0); - ut_a(xdes_get_n_used(descr, &mtr) < FSP_EXTENT_SIZE); - ut_a(xdes_get_state(descr, &mtr) == XDES_FREE_FRAG); - - n_used += xdes_get_n_used(descr, &mtr); - node_addr = flst_get_next_addr(descr + XDES_FLST_NODE, &mtr); - - mtr_commit(&mtr); - } - - /* Validate FSP_FULL_FRAG list */ - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - header = fsp_get_space_header(space, &mtr); - node_addr = flst_get_first(header + FSP_FULL_FRAG, &mtr); - - mtr_commit(&mtr); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - descr_count++; - descr = xdes_lst_get_descriptor(space, node_addr, &mtr); - - ut_a(xdes_get_n_used(descr, &mtr) == FSP_EXTENT_SIZE); - ut_a(xdes_get_state(descr, &mtr) == XDES_FULL_FRAG); - - node_addr = flst_get_next_addr(descr + XDES_FLST_NODE, &mtr); - mtr_commit(&mtr); - } - - /* Validate segments */ - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - header = fsp_get_space_header(space, &mtr); - node_addr = flst_get_first(header + FSP_SEGS, &mtr); - - mtr_commit(&mtr); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - seg_header = fut_get_ptr_x_lock(space, node_addr, - &mtr) - FSEG_FLST_NODE; - fseg_validate_low(seg_header, &mtr); - - descr_count += flst_get_len(seg_header + FSEG_FREE, &mtr); - descr_count += flst_get_len(seg_header + FSEG_FULL, &mtr); - descr_count += flst_get_len(seg_header + FSEG_NOT_FULL, &mtr); - - n_used2 += flst_get_len(seg_header + FSEG_FRAG, &mtr); - - node_addr = flst_get_next_addr(seg_header + FSEG_FLST_NODE, - &mtr); - mtr_commit(&mtr); - } - - ut_a(descr_count * FSP_EXTENT_SIZE == free_limit); - ut_a(n_used + n_full_frag_pages - == n_used2 + (free_limit + XDES_DESCRIBED_PER_PAGE - 1) - / XDES_DESCRIBED_PER_PAGE); - ut_a(frag_n_used == n_used); - - mtr_commit(&mtr2); - return(TRUE); -} - -/*********************************************************************** -Prints info of a file space. */ - -void -fsp_print( -/*======*/ - ulint space) /* in: space id */ -{ - fsp_header_t* header; - fseg_header_t* seg_header; - ulint size; - ulint free_limit; - ulint frag_n_used; - mtr_t mtr; - mtr_t mtr2; - fil_addr_t node_addr; - ulint n_free; - ulint n_free_frag; - ulint n_full_frag; - ulint n_segs; - ulint seg_id_low; - ulint seg_id_high; - - /* Start first a mini-transaction mtr2 to lock out all other threads - from the fsp system */ - mtr_start(&mtr2); - mtr_x_lock(&fsp_latch, &mtr2); - - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - header = fsp_get_space_header(space, &mtr); - - size = mtr_read_ulint(header + FSP_SIZE, MLOG_4BYTES, &mtr); - free_limit = mtr_read_ulint(header + FSP_FREE_LIMIT, - MLOG_4BYTES, &mtr); - frag_n_used = mtr_read_ulint(header + FSP_FRAG_N_USED, - MLOG_4BYTES, &mtr); - - n_free = flst_get_len(header + FSP_FREE, &mtr); - n_free_frag = flst_get_len(header + FSP_FREE_FRAG, &mtr); - n_full_frag = flst_get_len(header + FSP_FULL_FRAG, &mtr); - n_segs = flst_get_len(header + FSP_SEGS, &mtr); - seg_id_low = ut_dulint_get_low(mtr_read_dulint(header + FSP_SEG_ID, - MLOG_8BYTES, &mtr)); - seg_id_high = ut_dulint_get_high(mtr_read_dulint(header + FSP_SEG_ID, - MLOG_8BYTES, &mtr)); - - printf("FILE SPACE INFO: id %lu\n", space); - - printf("size %lu, free limit %lu, free extents %lu\n", - size, free_limit, n_free); - printf( - "not full frag extents %lu: used pages %lu, full frag extents %lu\n", - n_free_frag, frag_n_used, n_full_frag); - - printf("number of segments %lu, first seg id not used %lu %lu\n", - n_segs, seg_id_high, seg_id_low); - - /* Print segments */ - node_addr = flst_get_first(header + FSP_SEGS, &mtr); - - mtr_commit(&mtr); - - while (!fil_addr_is_null(node_addr)) { - mtr_start(&mtr); - mtr_x_lock(&fsp_latch, &mtr); - - seg_header = fut_get_ptr_x_lock(space, node_addr, - &mtr) - FSEG_FLST_NODE; - fseg_print_low(seg_header, &mtr); - - node_addr = flst_get_next_addr(seg_header + FSEG_FLST_NODE, - &mtr); - mtr_commit(&mtr); - } - - mtr_commit(&mtr2); -} - diff --git a/innobase/fsp/ts/del.c b/innobase/fsp/ts/del.c deleted file mode 100644 index 885797bdc76..00000000000 --- a/innobase/fsp/ts/del.c +++ /dev/null @@ -1,891 +0,0 @@ -/************************************************************************ -The test module for the file system and buffer manager - -(c) 1995 Innobase Oy - -Created 11/16/1995 Heikki Tuuri -*************************************************************************/ - -#include "string.h" - -#include "os0thread.h" -#include "os0file.h" -#include "ut0ut.h" -#include "ut0byte.h" -#include "sync0sync.h" -#include "mem0mem.h" -#include "fil0fil.h" -#include "..\buf0buf.h" -#include "..\buf0buf.h1" -#include "..\buf0buf.h2" -#include "..\buf0flu.h" -#include "..\buf0lru.h" -#include "mtr0buf.h" -#include "mtr0log.h" -#include "fsp0fsp.h" -#include "log0log.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[5]; - - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************ -Creates the test database files. */ - -void -create_db(void) -/*===========*/ -{ - ulint i; - buf_block_t* block; - byte* frame; - ulint j; - ulint tm, oldtm; - mtr_t mtr; - - oldtm = ut_clock(); - - for (i = 0; i < 1; i++) { - for (j = 0; j < 4096; j++) { - mtr_start(&mtr); - if (j == 0) { - fsp_header_init(i, 4096, &mtr); - - block = mtr_page_get(i, j, NULL, &mtr); - } else { - block = mtr_page_create(i, j, &mtr); - } - - frame = buf_block_get_frame(block); - - mtr_page_x_lock(block, &mtr); - - mlog_write_ulint(frame + FIL_PAGE_PREV, - j - 1, MLOG_4BYTES, &mtr); - - mlog_write_ulint(frame + FIL_PAGE_NEXT, - j + 1, MLOG_4BYTES, &mtr); - - mlog_write_ulint(frame + FIL_PAGE_OFFSET, - j, MLOG_4BYTES, &mtr); - - mtr_commit(&mtr); - } - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - /* Flush the pool of dirty pages by reading low-offset pages */ - for (i = 0; i < 1000; i++) { - - mtr_start(&mtr); - block = mtr_page_get(0, i, NULL, &mtr); - - frame = buf_block_get_frame(block); - - mtr_page_s_lock(block, &mtr); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, MLOG_4BYTES, - &mtr) == i); - - mtr_commit(&mtr); - } - - os_thread_sleep(1000000); - - ut_a(buf_all_freed()); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - strcpy(name, "j:\\tsfile1"); - - for (k = 0; k < 1; k++) { - for (i = 0; i < 4; i++) { - - name[9] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_set_size(files[i], 4096 * 8192, 0); - ut_a(ret); - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create("noname", k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, 4096, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Reads the test database files. */ - -void -test1(void) -/*=======*/ -{ - ulint i, j, k; - buf_block_t* block; - byte* frame; - ulint tm, oldtm; - - buf_flush_batch(BUF_FLUSH_LIST, 1000); - - os_thread_sleep(1000000); - - buf_all_freed(); - - oldtm = ut_clock(); - - for (k = 0; k < 1; k++) { - for (i = 0; i < 1; i++) { - for (j = 0; j < 409; j++) { - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - buf_page_s_lock(block); - - ut_a(*((ulint*)(frame + 16)) == j); - - buf_page_s_unlock(block); - - buf_page_release(block); - } - } - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - -} - -/************************************************************************ -Reads the test database files. */ - -void -test2(void) -/*=======*/ -{ - ulint i, j, k, rnd; - buf_block_t* block; - byte* frame; - ulint tm, oldtm; - - oldtm = ut_clock(); - - rnd = 123; - - for (k = 0; k < 100; k++) { - rnd += 23651; - rnd = rnd % 4096; - - i = rnd / 4096; - j = rnd % 2048; - - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - buf_page_s_lock(block); - - ut_a(*((ulint*)(frame + 16)) == j); - - buf_page_s_unlock(block); - - buf_page_release(block); - } - - tm = ut_clock(); - printf("Wall clock time for random read %lu milliseconds\n", - tm - oldtm); -} - -/************************************************************************ -Reads the test database files. */ - -void -test4(void) -/*=======*/ -{ - ulint i, j, k, rnd; - buf_block_t* block; - byte* frame; - ulint tm, oldtm; - - /* Flush the pool of high-offset pages */ - for (i = 0; i < 1000; i++) { - - block = buf_page_get(0, i, NULL); - - frame = buf_block_get_frame(block); - - buf_page_s_lock(block); - - ut_a(*((ulint*)(frame + 16)) == i); - - buf_page_s_unlock(block); - - buf_page_release(block); - } - - printf("Test starts\n"); - - oldtm = ut_clock(); - - rnd = 123; - - for (k = 0; k < 400; k++) { - - rnd += 4357; - - i = 0; - j = 1001 + rnd % 3000; - - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - buf_page_s_lock(block); - - ut_a(*((ulint*)(frame + 16)) == j); - - buf_page_s_unlock(block); - - buf_page_release(block); - } - - tm = ut_clock(); - printf( - "Wall clock time for %lu random no read-ahead %lu milliseconds\n", - k, tm - oldtm); - - /* Flush the pool of high-offset pages */ - for (i = 0; i < 1000; i++) { - - block = buf_page_get(0, i, NULL); - - frame = buf_block_get_frame(block); - - buf_page_s_lock(block); - - ut_a(*((ulint*)(frame + 16)) == i); - - buf_page_s_unlock(block); - - buf_page_release(block); - } - - printf("Test starts\n"); - - oldtm = ut_clock(); - - rnd = 123; - - for (k = 0; k < 400; k++) { - - rnd += 4357; - - i = 0; - j = 1001 + rnd % 400; - - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - buf_page_s_lock(block); - - ut_a(*((ulint*)(frame + 16)) == j); - - buf_page_s_unlock(block); - - buf_page_release(block); - } - - tm = ut_clock(); - printf( - "Wall clock time for %lu random read-ahead %lu milliseconds\n", - k, tm - oldtm); - -} - -/************************************************************************ -Tests speed of CPU algorithms. */ - -void -test3(void) -/*=======*/ -{ - ulint i, j; - buf_block_t* block; - ulint tm, oldtm; - - for (i = 0; i < 400; i++) { - - block = buf_page_get(0, i, NULL); - - buf_page_release(block); - } - - os_thread_sleep(2000000); - - oldtm = ut_clock(); - - for (j = 0; j < 500; j++) { - for (i = 0; i < 200; i++) { - - block = buf_page_get(0, i, NULL); - -/* - buf_page_s_lock(block); - - buf_page_s_unlock(block); -*/ - - buf_page_release(block); - - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu page get-release %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (j = 0; j < 500; j++) { - for (i = 0; i < 200; i++) { - - buf_page_get(0, i, NULL); -/* - buf_page_s_lock(block); - - buf_page_s_unlock(block); -*/ - buf_page_release(block); - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu block get-release %lu milliseconds\n", - i * j, tm - oldtm); - - - oldtm = ut_clock(); - - for (i = 0; i < 100000; i++) { - block = buf_block_alloc(); - buf_block_free(block); - } - - tm = ut_clock(); - printf("Wall clock time for %lu block alloc-free %lu milliseconds\n", - i, tm - oldtm); - - ha_print_info(buf_pool->page_hash); -} - -/************************************************************************ -Frees the spaces in the file system. */ - -void -free_system(void) -/*=============*/ -{ - ulint i; - - for (i = 0; i < 1; i++) { - fil_space_free(i); - } -} - -/************************************************************************ -Test for file space management. */ - -void -test5(void) -/*=======*/ -{ - mtr_t mtr; - ulint seg_page; - ulint new_page; - ulint seg_page2; - ulint new_page2; - buf_block_t* block; - bool finished; - ulint i; - ulint reserved; - ulint used; - ulint tm, oldtm; - - os_thread_sleep(1000000); - - buf_validate(); - - buf_print(); - - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, 555, &mtr); - - mtr_commit(&mtr); - - os_thread_sleep(1000000); - buf_validate(); - printf("Segment created: header page %lu\n", seg_page); - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - new_page = fseg_alloc_free_page(buf_block_get_frame(block) + 1000, - 2, FSP_UP, &mtr); - - mtr_commit(&mtr); - - buf_validate(); - buf_print(); - printf("Segment page allocated %lu\n", new_page); - - finished = FALSE; - - while (!finished) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - } - - /***********************************************/ - os_thread_sleep(1000000); - buf_validate(); - buf_print(); - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, 557, &mtr); - - mtr_commit(&mtr); - - ut_a(seg_page == 1); - - printf("Segment created: header page %lu\n", seg_page); - - new_page = seg_page; - for (i = 0; i < 1023; i++) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - new_page = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page + 1, FSP_UP, &mtr); - if (i < FSP_EXTENT_SIZE - 1) { - ut_a(new_page == 2 + i); - } else { - ut_a(new_page == i + FSP_EXTENT_SIZE + 1); - } - - printf("%lu %lu; ", i, new_page); - if (i % 10 == 0) { - printf("\n"); - } - - mtr_commit(&mtr); - } - - buf_print(); - buf_validate(); - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - mtr_page_s_lock(block, &mtr); - - reserved = fseg_n_reserved_pages(buf_block_get_frame(block) + 1000, - &used, &mtr); - - ut_a(used == 1024); - ut_a(reserved >= 1024); - - printf("Pages used in segment %lu reserved by segment %lu \n", - used, reserved); - - mtr_commit(&mtr); - - finished = FALSE; - - while (!finished) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - } - - buf_print(); - buf_validate(); - - /***********************************************/ - - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, 557, &mtr); - - mtr_commit(&mtr); - - ut_a(seg_page == 1); - - mtr_start(&mtr); - - seg_page2 = fseg_create(0, 0, 1000, 558, &mtr); - - mtr_commit(&mtr); - - ut_a(seg_page2 == 2); - - new_page = seg_page; - new_page2 = seg_page2; - - for (;;) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - new_page = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page + 1, FSP_UP, &mtr); - - printf("1:%lu %lu; ", i, new_page); - if (i % 10 == 0) { - printf("\n"); - } - - new_page = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page + 1, FSP_UP, &mtr); - - printf("1:%lu %lu; ", i, new_page); - if (i % 10 == 0) { - printf("\n"); - } - - mtr_commit(&mtr); - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page2, NULL, &mtr); - - new_page2 = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page2 + 1, FSP_UP, &mtr); - - printf("2:%lu %lu; ", i, new_page2); - if (i % 10 == 0) { - printf("\n"); - } - - mtr_commit(&mtr); - - if (new_page2 == FIL_NULL) { - break; - } - } - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - mtr_page_s_lock(block, &mtr); - - reserved = fseg_n_reserved_pages(buf_block_get_frame(block) + 1000, - &used, &mtr); - - printf("Pages used in segment 1 %lu, reserved by segment %lu \n", - used, reserved); - - mtr_commit(&mtr); - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page2, NULL, &mtr); - - mtr_page_s_lock(block, &mtr); - - reserved = fseg_n_reserved_pages(buf_block_get_frame(block) + 1000, - &used, &mtr); - - printf("Pages used in segment 2 %lu, reserved by segment %lu \n", - used, reserved); - - mtr_commit(&mtr); - - for (;;) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - block = mtr_page_get(0, seg_page2, NULL, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - } - - mtr_start(&mtr); - - seg_page2 = fseg_create(0, 0, 1000, 558, &mtr); - - mtr_commit(&mtr); - - i = 0; - for (;;) { - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page2, NULL, &mtr); - - new_page2 = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - 557, FSP_DOWN, &mtr); - - printf("%lu %lu; ", i, new_page2); - mtr_commit(&mtr); - - if (new_page2 == FIL_NULL) { - break; - } - i++; - } - - for (;;) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - } - - for (;;) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page2, NULL, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - } - - - /***************************************/ - - oldtm = ut_clock(); - - for (i = 0; i < 1000; i++) { - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, 555, &mtr); - - mtr_commit(&mtr); - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - new_page = fseg_alloc_free_page(buf_block_get_frame(block) + 1000, - 2, FSP_UP, &mtr); - - mtr_commit(&mtr); - - finished = FALSE; - - while (!finished) { - - mtr_start(&mtr); - - block = mtr_page_get(0, seg_page, NULL, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu seg crea+free %lu millisecs\n", - i, tm - oldtm); - - buf_validate(); - - buf_flush_batch(BUF_FLUSH_LIST, 500); - - os_thread_sleep(1000000); - - buf_all_freed(); -} - - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - ulint n; - - oldtm = ut_clock(); - - os_aio_init(160, 5); - sync_init(); - mem_init(); - fil_init(26); /* Allow 25 open files at a time */ - buf_pool_init(1000, 1000); - log_init(); - - buf_validate(); - - ut_a(fil_validate()); - - create_files(); - - create_db(); - - buf_validate(); - - test5(); -/* - test1(); - - test3(); - - test4(); - - test2(); -*/ - buf_validate(); - - n = buf_flush_batch(BUF_FLUSH_LIST, 500); - - os_thread_sleep(1000000); - - buf_all_freed(); - - free_system(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/fsp/ts/makefile b/innobase/fsp/ts/makefile deleted file mode 100644 index cd56e791b31..00000000000 --- a/innobase/fsp/ts/makefile +++ /dev/null @@ -1,16 +0,0 @@ - - - -include ..\..\makefile.i - -tsfsp: ..\fsp.lib tsfsp.c - $(CCOM) $(CFL) -I.. -I..\.. ..\..\btr.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsfsp.c $(LFL) - - - - - - - - - diff --git a/innobase/fsp/ts/tsfsp.c b/innobase/fsp/ts/tsfsp.c deleted file mode 100644 index ba6a35ebc69..00000000000 --- a/innobase/fsp/ts/tsfsp.c +++ /dev/null @@ -1,1234 +0,0 @@ -/************************************************************************ -The test module for file space management - -(c) 1996 Innobase Oy - -Created 1/4/1996 Heikki Tuuri -*************************************************************************/ - -#include "string.h" - -#include "os0thread.h" -#include "os0file.h" -#include "ut0ut.h" -#include "ut0byte.h" -#include "sync0sync.h" -#include "mem0mem.h" -#include "fil0fil.h" -#include "mach0data.h" -#include "buf0buf.h" -#include "buf0flu.h" -#include "log0log.h" -#include "fut0lst.h" -#include "fut0fut.h" -#include "mtr0mtr.h" -#include "mtr0log.h" -#include "..\fsp0fsp.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; -ulint page_nos[10000]; - -#define N_SPACES 1 -#define N_FILES 2 -#define FILE_SIZE 1000 /* must be > 512 */ -#define POOL_SIZE 1000 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Creates the test database files. */ - -void -create_db(void) -/*===========*/ -{ - ulint i; - buf_block_t* block; - byte* frame; - ulint j; - ulint tm, oldtm; - mtr_t mtr; - - printf("--------------------------------------------------------\n"); - printf("Write database pages\n"); - - oldtm = ut_clock(); - - for (i = 0; i < N_SPACES; i++) { - for (j = 0; j < FILE_SIZE * N_FILES; j++) { - mtr_start(&mtr); - - block = buf_page_create(i, j, &mtr); - - frame = buf_block_get_frame(block); - - buf_page_x_lock(block, &mtr); - - if (j > FILE_SIZE * N_FILES - - 64 * 2 - 1) { - mlog_write_ulint(frame + FIL_PAGE_PREV, j - 5, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + FIL_PAGE_NEXT, j - 7, - MLOG_4BYTES, &mtr); - } else { - mlog_write_ulint(frame + FIL_PAGE_PREV, j - 1, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + FIL_PAGE_NEXT, j + 1, - MLOG_4BYTES, &mtr); - } - - mlog_write_ulint(frame + FIL_PAGE_OFFSET, j, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + FIL_PAGE_SPACE, i, - MLOG_4BYTES, &mtr); - mlog_write_ulint(frame + COUNTER_OFFSET, 0, - MLOG_4BYTES, &mtr); - - mtr_commit(&mtr); - } - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); -} - -/************************************************************************ -Reads the test database files. */ - -void -test1(void) -/*=======*/ -{ - ulint i, j, k; - buf_block_t* block; - byte* frame; - ulint tm, oldtm; - mtr_t mtr; - - printf("--------------------------------------------------------\n"); - printf("TEST 1. Read linearly database files\n"); - - oldtm = ut_clock(); - - for (k = 0; k < 1; k++) { - for (i = 0; i < N_SPACES; i++) { - for (j = 0; j < N_FILES * FILE_SIZE; j++) { - mtr_start(&mtr); - - block = buf_page_get(i, j, &mtr); - - frame = buf_block_get_frame(block); - - buf_page_s_lock(block, &mtr); - - ut_a(mtr_read_ulint(frame + FIL_PAGE_OFFSET, - MLOG_4BYTES, &mtr) - == j); - ut_a(mtr_read_ulint(frame + FIL_PAGE_SPACE, - MLOG_4BYTES, &mtr) - == i); - - mtr_commit(&mtr); - } - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu pages %lu milliseconds\n", - k * i * j, tm - oldtm); - buf_validate(); -} - -/************************************************************************ -Test for file-based lists. */ - -void -test2(void) -/*=======*/ -{ - mtr_t mtr; - buf_frame_t* frame; - buf_block_t* block; - ulint i; - flst_base_node_t* base1; - fil_addr_t base_addr1; - flst_base_node_t* base2; - fil_addr_t base_addr2; - flst_node_t* node; - fil_addr_t node_addr; - flst_node_t* node2; - fil_addr_t node_addr2; - flst_node_t* node3; - fil_addr_t node_addr3; - -#define BPAGE 10 -#define BASE1 300 -#define BASE2 500 -#define NODE1 800 -#define NODE2 900 -#define NODE3 1000 -#define NODE4 1100 -#define INDEX 30 - - buf_validate(); - - mtr_start(&mtr); - - block = buf_page_get(0, BPAGE, &mtr); - frame = buf_block_get_frame(block); - - flst_init(frame + BASE1, &mtr); - flst_init(frame + BASE2, &mtr); - - mtr_commit(&mtr); - - printf("-------------------------------------------\n"); - printf("TEST 2. Test of file-based two-way lists \n"); - - base_addr1.page = BPAGE; - base_addr1.boffset = BASE1; - - base_addr2.page = BPAGE; - base_addr2.boffset = BASE2; - - printf( - "Add 1000 elements in list1 in reversed order and in list2 in order\n"); - for (i = 0; i < 1000; i++) { - mtr_start(&mtr); - - base1 = fut_get_ptr(0, base_addr1, &mtr); - base2 = fut_get_ptr(0, base_addr2, &mtr); - - block = buf_page_get(0, i, &mtr); - frame = buf_block_get_frame(block); - - buf_page_x_lock(block, &mtr); - - flst_add_first(base1, frame + NODE1, &mtr); - mlog_write_ulint(frame + NODE1 + INDEX, i, - MLOG_4BYTES, &mtr); - flst_add_last(base2, frame + NODE2, &mtr); - mlog_write_ulint(frame + NODE2 + INDEX, i, - MLOG_4BYTES, &mtr); - - mtr_commit(&mtr); - } - - mtr_start(&mtr); - - base1 = fut_get_ptr(0, base_addr1, &mtr); - base2 = fut_get_ptr(0, base_addr2, &mtr); - - flst_validate(base1, &mtr); - flst_validate(base2, &mtr); - - flst_print(base1, &mtr); - flst_print(base2, &mtr); - - mtr_commit(&mtr); - - mtr_start(&mtr); - - base1 = fut_get_ptr_s_lock(0, base_addr1, &mtr); - - node_addr = flst_get_first(base1, &mtr); - - mtr_commit(&mtr); - - printf("Check order of elements in list1\n"); - for (i = 0; i < 1000; i++) { - mtr_start(&mtr); - ut_a(!fil_addr_is_null(node_addr)); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - ut_a(mtr_read_ulint(node + INDEX, MLOG_4BYTES, &mtr) == - 999 - i); - - node_addr = flst_get_next_addr(node, &mtr); - mtr_commit(&mtr); - } - - ut_a(fil_addr_is_null(node_addr)); - - mtr_start(&mtr); - - base2 = fut_get_ptr_s_lock(0, base_addr2, &mtr); - - node_addr = flst_get_first(base2, &mtr); - - mtr_commit(&mtr); - - printf("Check order of elements in list2\n"); - for (i = 0; i < 1000; i++) { - mtr_start(&mtr); - ut_a(!fil_addr_is_null(node_addr)); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - ut_a(mtr_read_ulint(node + INDEX, MLOG_4BYTES, &mtr) - == i); - - node_addr = flst_get_next_addr(node, &mtr); - mtr_commit(&mtr); - } - - ut_a(fil_addr_is_null(node_addr)); - - mtr_start(&mtr); - - base1 = fut_get_ptr(0, base_addr1, &mtr); - base2 = fut_get_ptr(0, base_addr2, &mtr); - - flst_validate(base1, &mtr); - flst_validate(base2, &mtr); - - mtr_commit(&mtr); - - mtr_start(&mtr); - - base1 = fut_get_ptr_s_lock(0, base_addr1, &mtr); - - node_addr = flst_get_first(base1, &mtr); - - mtr_commit(&mtr); - - for (i = 0; i < 500; i++) { - mtr_start(&mtr); - ut_a(!fil_addr_is_null(node_addr)); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - node_addr = flst_get_next_addr(node, &mtr); - mtr_commit(&mtr); - } - - printf("Add 200 elements to the middle of list1\n"); - for (i = 0; i < 100; i++) { - mtr_start(&mtr); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - node_addr2.page = i; - node_addr2.boffset = NODE3; - node2 = fut_get_ptr_x_lock(0, node_addr2, &mtr); - - node_addr3.page = i; - node_addr3.boffset = NODE4; - node3 = fut_get_ptr_x_lock(0, node_addr3, &mtr); - - mlog_write_ulint(node2 + INDEX, 99 - i, MLOG_4BYTES, &mtr); - - block = buf_page_get(0, BPAGE, &mtr); - frame = buf_block_get_frame(block); - - base1 = frame + BASE1; - - flst_insert_after(base1, node, node2, &mtr); - flst_insert_before(base1, node3, node, &mtr); - - if (i % 17 == 0) { - flst_validate(base1, &mtr); - } - mtr_commit(&mtr); - } - - printf("Check that 100 of the inserted nodes are in order\n"); - mtr_start(&mtr); - ut_a(!fil_addr_is_null(node_addr)); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - node_addr = flst_get_next_addr(node, &mtr); - mtr_commit(&mtr); - - for (i = 0; i < 100; i++) { - mtr_start(&mtr); - ut_a(!fil_addr_is_null(node_addr)); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - ut_a(mtr_read_ulint(node + INDEX, MLOG_4BYTES, &mtr) - == i); - - node_addr = flst_get_next_addr(node, &mtr); - mtr_commit(&mtr); - } - - printf("Remove 899 elements from the middle of list1\n"); - mtr_start(&mtr); - - base1 = fut_get_ptr_x_lock(0, base_addr1, &mtr); - - node_addr = flst_get_first(base1, &mtr); - - flst_print(base1, &mtr); - mtr_commit(&mtr); - - for (i = 0; i < 300; i++) { - mtr_start(&mtr); - ut_a(!fil_addr_is_null(node_addr)); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - node_addr = flst_get_next_addr(node, &mtr); - mtr_commit(&mtr); - } - - for (i = 0; i < 899; i++) { - - mtr_start(&mtr); - - base1 = fut_get_ptr_x_lock(0, base_addr1, &mtr); - - node_addr = flst_get_first(base1, &mtr); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - node_addr = flst_get_next_addr(node, &mtr); - - ut_a(!fil_addr_is_null(node_addr)); - - node2 = fut_get_ptr_x_lock(0, node_addr, &mtr); - - flst_remove(base1, node2, &mtr); - - if (i % 17 == 0) { - flst_validate(base1, &mtr); - } - - mtr_commit(&mtr); - } - - printf("Remove 301 elements from the start of list1\n"); - for (i = 0; i < 301; i++) { - - mtr_start(&mtr); - - base1 = fut_get_ptr_x_lock(0, base_addr1, &mtr); - - node_addr = flst_get_first(base1, &mtr); - - node = fut_get_ptr_x_lock(0, node_addr, &mtr); - - flst_remove(base1, node, &mtr); - - if (i % 17 == 0) { - flst_validate(base1, &mtr); - } - - mtr_commit(&mtr); - } - - mtr_start(&mtr); - - base1 = fut_get_ptr_x_lock(0, base_addr1, &mtr); - - ut_a(flst_get_len(base1, &mtr) == 0); - flst_print(base1, &mtr); - - mtr_commit(&mtr); -} - -/************************************************************************ -Inits space header of space 0. */ - -void -init_space(void) -/*============*/ -{ - mtr_t mtr; - - printf("Init space header\n"); - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - - mtr_commit(&mtr); -} - -/************************************************************************ -Test for file space management. */ - -void -test5(void) -/*=======*/ -{ - mtr_t mtr; - ulint seg_page; - ulint new_page; - ulint seg_page2; - ulint new_page2; - ulint seg_page3; - buf_block_t* block; - bool finished; - ulint i; - ulint reserved; - ulint used; - ulint tm, oldtm; - - buf_validate(); - - fsp_validate(0); - fsp_print(0); - - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, &mtr); - - mtr_commit(&mtr); - - fsp_validate(0); - - buf_validate(); - printf("Segment created: header page %lu, byte offset %lu\n", - seg_page, 1000); - fsp_print(0); - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - new_page = fseg_alloc_free_page(buf_block_get_frame(block) + 1000, - 2, FSP_UP, &mtr); - - mtr_commit(&mtr); - - fsp_print(0); - fsp_validate(0); - buf_validate(); - printf("Segment page allocated %lu\n", new_page); - - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - fseg_free_page(buf_block_get_frame(block) + 1000, - 0, new_page, &mtr); - - mtr_commit(&mtr); - - fsp_validate(0); - printf("Segment page freed %lu\n", new_page); - - finished = FALSE; - - while (!finished) { - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - } - fsp_validate(0); - - /***********************************************/ - buf_validate(); - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, &mtr); - - mtr_commit(&mtr); - - ut_a(seg_page == 2); - - printf("Segment created: header page %lu\n", seg_page); - - new_page = seg_page; - for (i = 0; i < 511; i++) { - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - new_page = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page + 1, FSP_UP, &mtr); - printf("%lu %lu; ", i, new_page); - if (i % 10 == 0) { - printf("\n"); - } - - mtr_commit(&mtr); - - if (i % 117 == 0) { - fsp_validate(0); - } - } - - fsp_validate(0); - buf_validate(); - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - reserved = fseg_n_reserved_pages(buf_block_get_frame(block) + 1000, - &used, &mtr); - - ut_a(used == 512); - ut_a(reserved >= 512); - - printf("Pages used in segment %lu reserved by segment %lu \n", - used, reserved); - - mtr_commit(&mtr); - - finished = FALSE; - - while (!finished) { - i++; - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (i % 117 == 0) { - fsp_validate(0); - } - } - - fsp_validate(0); - buf_validate(); - - /***********************************************/ - - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, &mtr); - - mtr_commit(&mtr); - - ut_a(seg_page == 2); - - mtr_start(&mtr); - - seg_page2 = fseg_create(0, 0, 1000, &mtr); - - mtr_commit(&mtr); - - ut_a(seg_page2 == 3); - - new_page = seg_page; - new_page2 = seg_page2; - - for (;;) { - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - new_page = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page + 1, FSP_UP, &mtr); - - printf("1:%lu %lu; ", i, new_page); - if (i % 10 == 0) { - printf("\n"); - } - - new_page = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page + 1, FSP_UP, &mtr); - - printf("1:%lu %lu; ", i, new_page); - if (i % 10 == 0) { - printf("\n"); - } - - mtr_commit(&mtr); - - i++; - if (i % 217 == 0) { - fsp_validate(0); - } - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page2, &mtr); - - new_page2 = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page2 + 1, FSP_DOWN, &mtr); - - printf("2:%lu %lu; ", i, new_page2); - if (i % 10 == 0) { - printf("\n"); - } - - mtr_commit(&mtr); - - if (new_page2 == FIL_NULL) { - break; - } - } - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - reserved = fseg_n_reserved_pages(buf_block_get_frame(block) + 1000, - &used, &mtr); - - printf("Pages used in segment 1 %lu, reserved by segment %lu \n", - used, reserved); - - mtr_commit(&mtr); - fsp_validate(0); - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page2, &mtr); - - reserved = fseg_n_reserved_pages(buf_block_get_frame(block) + 1000, - &used, &mtr); - - printf("Pages used in segment 2 %lu, reserved by segment %lu \n", - used, reserved); - - mtr_commit(&mtr); - - fsp_print(0); - - for (;;) { - - i++; - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - block = buf_page_get(0, seg_page2, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - - if (i % 117 == 0) { - fsp_validate(0); - } - } - - fsp_validate(0); - - mtr_start(&mtr); - - seg_page3 = fseg_create(0, 0, 1000, &mtr); - page_nos[0] = seg_page3; - new_page2 = seg_page3; - - mtr_commit(&mtr); - - for (i = 1; i < 250; i++) { - mtr_start(&mtr); - - block = buf_page_get(0, seg_page3, &mtr); - - new_page2 = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page2 + 1, FSP_UP, &mtr); - page_nos[i] = new_page2; - - mtr_commit(&mtr); - } - - /*************************************************/ - - mtr_start(&mtr); - - fseg_create(0, seg_page3, 1500, &mtr); - - mtr_commit(&mtr); - - for (i = 0; i < 250; i++) { - mtr_start(&mtr); - - block = buf_page_get(0, seg_page3, &mtr); - - new_page2 = fseg_alloc_free_page( - buf_block_get_frame(block) + 1500, - new_page2 + 1, FSP_UP, &mtr); - page_nos[i] = new_page2; - - mtr_commit(&mtr); - } - - printf("---------------------------------------------------------\n"); - printf("TEST 5A13. Test free_step.\n"); - - fseg_free(0, seg_page3, 1500); - - printf("---------------------------------------------------------\n"); - printf("TEST 5A3. Test free_step.\n"); - - for (;;) { - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page3, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - } - - /***************************************************/ - - mtr_start(&mtr); - - seg_page2 = fseg_create(0, 0, 1000, &mtr); - page_nos[0] = seg_page2; - new_page2 = seg_page2; - - mtr_commit(&mtr); - - i = 1; - for (;;) { - mtr_start(&mtr); - - block = buf_page_get(0, seg_page2, &mtr); - - new_page2 = fseg_alloc_free_page( - buf_block_get_frame(block) + 1000, - new_page2 + 1, FSP_UP, &mtr); - page_nos[i] = new_page2; -/* - printf("%lu %lu; ", i, new_page2); -*/ - mtr_commit(&mtr); - - if (new_page2 == FIL_NULL) { - break; - } - i++; - } - - printf("---------------------------------------------------------\n"); - printf("TEST 5D. Test free_step.\n"); - - for (;;) { - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - } - - for (;;) { - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page2, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - - if (finished) { - break; - } - } - - - /***************************************/ - - oldtm = ut_clock(); - - fsp_validate(0); - - for (i = 0; i < 10; i++) { - mtr_start(&mtr); - - seg_page = fseg_create(0, 0, 1000, &mtr); - - mtr_commit(&mtr); - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - new_page = fseg_alloc_free_page(buf_block_get_frame(block) + 1000, - 3, FSP_UP, &mtr); - - mtr_commit(&mtr); - - finished = FALSE; - - while (!finished) { - - mtr_start(&mtr); - - block = buf_page_get(0, seg_page, &mtr); - - finished = fseg_free_step( - buf_block_get_frame(block) + 1000, &mtr); - - mtr_commit(&mtr); - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu seg crea+free %lu millisecs\n", - i, tm - oldtm); - - buf_validate(); - fsp_validate(0); - fsp_print(0); - - buf_flush_batch(BUF_FLUSH_LIST, 2000); - os_thread_sleep(3000000); - -/* buf_print(); */ - buf_all_freed(); -} - -/************************************************************************ -Random test thread function. */ - -ulint -random_thread( -/*===========*/ - void* arg) -{ - ulint n; - ulint i, j, t, p, sp, d, b; - ulint s; - ulint arr[FILE_SIZE * N_FILES]; - ulint seg_page; - fseg_header_t* seg_header; - fil_addr_t seg_addr; - byte dir; - ulint k; - mtr_t mtr; - bool finished; - ulint used; - ulint reserved; - - n = *((ulint*)arg); - n = os_thread_get_curr_id(); - - printf("Random test thread %lu starts\n", n); - - for (i = 0; i < 30; i++) { - t = ut_rnd_gen_ulint() % 10; - s = ut_rnd_gen_ulint() % FILE_SIZE * N_FILES; - p = 0; - sp = ut_rnd_gen_ulint() % N_SPACES; - d = ut_rnd_gen_ulint() % 3; - b = ut_rnd_gen_ulint() % 3; - - if (i % 10 == 0) { - printf("Thr %lu round %lu starts\n", n, i); - } - ut_a(buf_validate()); - - if (t != 0) { - do { - mtr_start(&mtr); - seg_page = fseg_create(sp, p, 1000, &mtr); - mtr_commit(&mtr); - } while (seg_page == FIL_NULL); - - seg_addr.page = seg_page; - seg_addr.boffset = 1000; - - k = 0; - j = 0; - while (j < s) { - j++; - if (d == 0) { - dir = FSP_DOWN; - } else if (d == 1) { - dir = FSP_NO_DIR; - } else { - dir = FSP_UP; - } - mtr_start(&mtr); - seg_header = fut_get_ptr(sp, seg_addr, &mtr); - - if (b != 0) { - arr[k] = fseg_alloc_free_page(seg_header, - p, dir, &mtr); - k++; - } else if (k > 0) { - fseg_free_page(seg_header, sp, arr[k - 1], - &mtr); - k--; - } - - mtr_commit(&mtr); - if ((k > 0) && (arr[k - 1] == FIL_NULL)) { - k--; - break; - } - if (p > 0) { - p = arr[k - 1] + dir - 1; - } - if (j % 577 == 0) { - if (k > 0) { - p = arr[k / 2] + 1; - } else { - p = 0; - } - d = ut_rnd_gen_ulint() % 3; - b = ut_rnd_gen_ulint() % 3; - } - } - finished = FALSE; - mtr_start(&mtr); - - seg_header = fut_get_ptr(sp, seg_addr, &mtr); - - reserved = fseg_n_reserved_pages(seg_header, - &used, &mtr); - - printf("Pages used in segment %lu reserved by segment %lu \n", - used, reserved); - - mtr_commit(&mtr); - - printf("Thread %lu starts releasing seg %lu size %lu\n", n, - seg_addr.page, k); - while (!finished) { - mtr_start(&mtr); - seg_header = fut_get_ptr(sp, seg_addr, &mtr); - - finished = fseg_free_step(seg_header, &mtr); - mtr_commit(&mtr); - } - } else { - fsp_print(sp); - printf("Thread %lu validates fsp\n", n); - fsp_validate(sp); - buf_validate(); - } - } /* for i */ - printf("\nRandom test thread %lu exits\n", os_thread_get_curr_id()); - return(0); -} - -/************************************************************************* -Performs random operations on the buffer with several threads. */ - -void -test6(void) -/*=======*/ -{ - ulint i; - os_thread_t thr[N_THREADS + 1]; - os_thread_id_t id[N_THREADS + 1]; - ulint n[N_THREADS + 1]; - - printf("--------------------------------------------------------\n"); - printf("TEST 6. Random multi-thread test on the buffer \n"); - - incs = 0; - mutex_create(&incs_mutex); - - for (i = 0; i < N_THREADS; i++) { - n[i] = i; - - thr[i] = os_thread_create(random_thread, n + i, id + i); - } - - for (i = 0; i < N_THREADS; i++) { - os_thread_wait(thr[i]); - } -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - oldtm = ut_clock(); - - os_aio_init(160, 5); - sync_init(); - mem_init(); - fil_init(26); /* Allow 25 open files at a time */ - buf_pool_init(POOL_SIZE, POOL_SIZE); - log_init(); - fsp_init(); - - buf_validate(); - - ut_a(fil_validate()); - - create_files(); - - create_db(); - - buf_validate(); - -/* test1(); */ -/* buf_validate(); */ -/* - test2(); - buf_validate(); -*/ - init_space(); - - test5(); - buf_validate(); - -/* test6(); */ - - buf_flush_batch(BUF_FLUSH_LIST, POOL_SIZE + 1); -/* buf_print(); */ - buf_validate(); - - os_thread_sleep(1000000); - -/* buf_print(); */ - buf_all_freed(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/ha/ts/makefile b/innobase/ha/ts/makefile deleted file mode 100644 index aea21f11141..00000000000 --- a/innobase/ha/ts/makefile +++ /dev/null @@ -1,12 +0,0 @@ - -include ..\..\makefile.i - -tsha: ..\ha.lib tsha.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\..\btr.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsha.c $(LFL) - - - - - - - diff --git a/innobase/ha/ts/tsha.c b/innobase/ha/ts/tsha.c deleted file mode 100644 index fd9a2e12f6e..00000000000 --- a/innobase/ha/ts/tsha.c +++ /dev/null @@ -1,120 +0,0 @@ -/************************************************************************ -The test module for hash table - -(c) 1994, 1995 Innobase Oy - -Created 1/25/1994 Heikki Tuuri -*************************************************************************/ - -#include "ut0ut.h" -#include "ha0ha.h" -#include "mem0mem.h" -#include "sync0sync.h" - -ulint ulint_array[200000]; - -void -test1(void) -{ - hash_table_t* table1; - ulint i; - ulint n313 = 313; - ulint n414 = 414; - - printf("------------------------------------------------\n"); - printf("TEST 1. BASIC TEST\n"); - - table1 = ha_create(50000); - - ha_insert_for_fold(table1, 313, &n313); - - ha_insert_for_fold(table1, 313, &n414); - - ut_a(ha_validate(table1)); - - ha_delete(table1, 313, &n313); - ha_delete(table1, 313, &n414); - - ut_a(ha_validate(table1)); - - printf("------------------------------------------------\n"); - printf("TEST 2. TEST OF MASSIVE INSERTS AND DELETES\n"); - - table1 = ha_create(10000); - - for (i = 0; i < 200000; i++) { - ulint_array[i] = i; - } - - for (i = 0; i < 50000; i++) { - ha_insert_for_fold(table1, i * 7, ulint_array + i); - } - - ut_a(ha_validate(table1)); - - for (i = 0; i < 50000; i++) { - ha_delete(table1, i * 7, ulint_array + i); - } - - ut_a(ha_validate(table1)); -} - -void -test2(void) -{ - hash_table_t* table1; - ulint i; - ulint oldtm, tm; - ha_node_t* node; - - printf("------------------------------------------------\n"); - printf("TEST 3. SPEED TEST\n"); - - table1 = ha_create(300000); - - oldtm = ut_clock(); - - for (i = 0; i < 200000; i++) { - ha_insert_for_fold(table1, i * 27877, ulint_array + i); - } - - tm = ut_clock(); - - printf("Wall clock time for %lu inserts %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 200000; i++) { - node = ha_search(table1, i * 27877); - } - - tm = ut_clock(); - - printf("Wall clock time for %lu searches %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 200000; i++) { - ha_delete(table1, i * 27877, ulint_array + i); - } - - tm = ut_clock(); - - printf("Wall clock time for %lu deletes %lu millisecs\n", - i, tm - oldtm); -} - -void -main(void) -{ - sync_init(); - mem_init(1000000); - - test1(); - - test2(); - - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/include/Makefile.am b/innobase/include/Makefile.am index 8664f6dfc17..ab1f14d0770 100644 --- a/innobase/include/Makefile.am +++ b/innobase/include/Makefile.am @@ -50,7 +50,7 @@ noinst_HEADERS = btr0btr.h btr0btr.ic btr0cur.h btr0cur.ic \ thr0loc.h thr0loc.ic trx0purge.h trx0purge.ic trx0rec.h \ trx0rec.ic trx0roll.h trx0roll.ic trx0rseg.h trx0rseg.ic \ trx0sys.h trx0sys.ic trx0trx.h trx0trx.ic trx0types.h \ - trx0undo.h trx0undo.ic univ.i univold.i univoldmysql.i \ + trx0undo.h trx0undo.ic univ.i \ usr0sess.h usr0sess.ic usr0types.h ut0byte.h ut0byte.ic \ ut0dbg.h ut0lst.h ut0mem.h ut0mem.ic ut0rnd.h ut0rnd.ic \ ut0sort.h ut0ut.h ut0ut.ic diff --git a/innobase/include/mem0mem.ic b/innobase/include/mem0mem.ic index 1ff8c66e80a..e863fe41c4b 100644 --- a/innobase/include/mem0mem.ic +++ b/innobase/include/mem0mem.ic @@ -162,7 +162,7 @@ mem_heap_alloc( mem_block_set_free(block, free + MEM_SPACE_NEEDED(n)); - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG /* In the debug version write debugging info to the field */ mem_field_init((byte*)buf, n); @@ -171,7 +171,7 @@ mem_heap_alloc( caller */ buf = (byte*)buf + MEM_FIELD_HEADER_SIZE; - #endif +#endif #ifdef UNIV_SET_MEM_TO_ZERO memset(buf, '\0', n); #endif @@ -212,15 +212,15 @@ mem_heap_free_heap_top( { mem_block_t* block; mem_block_t* prev_block; - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG ibool error; ulint total_size; ulint size; - #endif +#endif ut_ad(mem_heap_check(heap)); - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG /* Validate the heap and get its total allocated size */ mem_heap_validate_or_print(heap, NULL, FALSE, &error, &total_size, @@ -232,7 +232,7 @@ mem_heap_free_heap_top( NULL); ut_a(!error); - #endif +#endif block = UT_LIST_GET_LAST(heap->base); @@ -259,7 +259,7 @@ mem_heap_free_heap_top( /* Set the free field of block */ mem_block_set_free(block, old_top - (byte*)block); - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG ut_ad(mem_block_get_start(block) <= mem_block_get_free(block)); /* In the debug version erase block from top up */ @@ -271,7 +271,7 @@ mem_heap_free_heap_top( mem_current_allocated_memory -= (total_size - size); mutex_exit(&mem_hash_mutex); - #endif +#endif /* If free == start, we may free the block if it is not the first one */ @@ -317,7 +317,7 @@ mem_heap_get_top( buf = (byte*)block + mem_block_get_free(block) - MEM_SPACE_NEEDED(n); - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG ut_ad(mem_block_get_start(block) <=(ulint)((byte*)buf - (byte*)block)); /* In the debug version, advance buf to point at the storage which @@ -327,7 +327,7 @@ mem_heap_get_top( /* Check that the field lengths agree */ ut_ad(n == (ulint)mem_field_header_get_len(buf)); - #endif +#endif return(buf); } @@ -351,13 +351,13 @@ mem_heap_free_top( /* Subtract the free field of block */ mem_block_set_free(block, mem_block_get_free(block) - MEM_SPACE_NEEDED(n)); - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG ut_ad(mem_block_get_start(block) <= mem_block_get_free(block)); /* In the debug version check the consistency, and erase field */ mem_field_erase((byte*)block + mem_block_get_free(block), n); - #endif +#endif /* If free == start, we may free the block if it is not the first one */ @@ -417,7 +417,7 @@ mem_heap_create_func( /* Add the created block itself as the first block in the list */ UT_LIST_ADD_FIRST(list, block->base, block); - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG if (block == NULL) { @@ -426,7 +426,7 @@ mem_heap_create_func( mem_hash_insert(block, file_name, line); - #endif +#endif return(block); } @@ -452,14 +452,14 @@ mem_heap_free_func( block = UT_LIST_GET_LAST(heap->base); - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG /* In the debug version remove the heap from the hash table of heaps and check its consistency */ mem_hash_remove(heap, file_name, line); - #endif +#endif if (heap->free_block) { mem_heap_free_block_free(heap); diff --git a/innobase/include/srv0start.h b/innobase/include/srv0start.h index 97a59fd14c7..0074de537c3 100644 --- a/innobase/include/srv0start.h +++ b/innobase/include/srv0start.h @@ -21,16 +21,6 @@ srv_normalize_path_for_win( /*=======================*/ char* str); /* in/out: null-terminated character string */ /************************************************************************* -Adds a slash or a backslash to the end of a string if it is missing -and the string is not empty. */ - -char* -srv_add_path_separator_if_needed( -/*=============================*/ - /* out, own: string which has the separator if the - string is not empty */ - char* str); /* in: null-terminated character string */ -/************************************************************************* Reads the data files and their sizes from a character string given in the .cnf file. */ diff --git a/innobase/include/sync0rw.ic b/innobase/include/sync0rw.ic index 36ef0a985ed..caf6f5f1de4 100644 --- a/innobase/include/sync0rw.ic +++ b/innobase/include/sync0rw.ic @@ -140,10 +140,10 @@ rw_lock_s_lock_low( /* Set the shared lock by incrementing the reader count */ lock->reader_count++; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, pass, RW_LOCK_SHARED, file_name, line); - #endif +#endif lock->last_s_file_name = file_name; lock->last_s_line = line; @@ -175,9 +175,9 @@ rw_lock_s_lock_direct( lock->last_s_file_name = file_name; lock->last_s_line = line; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, 0, RW_LOCK_SHARED, file_name, line); - #endif +#endif } /********************************************************************** @@ -204,9 +204,9 @@ rw_lock_x_lock_direct( lock->last_x_file_name = file_name; lock->last_x_line = line; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, 0, RW_LOCK_EX, file_name, line); - #endif +#endif } /********************************************************************** @@ -275,10 +275,10 @@ rw_lock_s_lock_func_nowait( /* Set the shared lock by incrementing the reader count */ lock->reader_count++; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, 0, RW_LOCK_SHARED, file_name, line); - #endif +#endif lock->last_s_file_name = file_name; lock->last_s_line = line; @@ -320,9 +320,9 @@ rw_lock_x_lock_func_nowait( lock->writer_count++; lock->pass = 0; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, 0, RW_LOCK_EX, file_name, line); - #endif +#endif lock->last_x_file_name = file_name; lock->last_x_line = line; @@ -361,9 +361,9 @@ rw_lock_s_unlock_func( ut_a(lock->reader_count > 0); lock->reader_count--; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_remove_debug_info(lock, pass, RW_LOCK_SHARED); - #endif +#endif /* If there may be waiters and this was the last s-lock, signal the object */ @@ -402,9 +402,9 @@ rw_lock_s_unlock_direct( lock->reader_count--; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_remove_debug_info(lock, 0, RW_LOCK_SHARED); - #endif +#endif ut_ad(!lock->waiters); ut_ad(rw_lock_validate(lock)); @@ -442,9 +442,9 @@ rw_lock_x_unlock_func( rw_lock_set_writer(lock, RW_LOCK_NOT_LOCKED); } - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_remove_debug_info(lock, pass, RW_LOCK_EX); - #endif +#endif /* If there may be waiters, signal the lock */ if (lock->waiters && (lock->writer_count == 0)) { @@ -486,9 +486,9 @@ rw_lock_x_unlock_direct( rw_lock_set_writer(lock, RW_LOCK_NOT_LOCKED); } - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_remove_debug_info(lock, 0, RW_LOCK_EX); - #endif +#endif ut_ad(!lock->waiters); ut_ad(rw_lock_validate(lock)); diff --git a/innobase/include/sync0sync.ic b/innobase/include/sync0sync.ic index c11cc0d196e..816b44a5bd3 100644 --- a/innobase/include/sync0sync.ic +++ b/innobase/include/sync0sync.ic @@ -250,9 +250,9 @@ mutex_enter_func( if (!mutex_test_and_set(mutex)) { - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG mutex_set_debug_info(mutex, file_name, line); - #endif +#endif mutex->file_name = file_name; mutex->line = line; diff --git a/innobase/include/univold.i b/innobase/include/univold.i deleted file mode 100644 index 8bcd28e180f..00000000000 --- a/innobase/include/univold.i +++ /dev/null @@ -1,164 +0,0 @@ -/*************************************************************************** -Version control for database, common definitions, and include files - -(c) 1994 - 2000 Innobase Oy - -Created 1/20/1994 Heikki Tuuri -****************************************************************************/ - -#ifndef univ_i -#define univ_i - -#define UNIV_INTEL -#define UNIV_PENTIUM -/* If UNIV_WINNT is not defined, we assume Windows 95 */ - -#define UNIV_WINNT -#define UNIV_WINNT4 -#define __NT__ - -#define UNIV_VISUALC - -#define __WIN__ -#define _WIN32_WINNT 0x0400 - -/* DEBUG VERSION CONTROL - ===================== */ -/* Make a non-inline debug version */ -/* -#define UNIV_DEBUG -#define UNIV_MEM_DEBUG -#define UNIV_SYNC_DEBUG -#define UNIV_SEARCH_DEBUG - -#define UNIV_IBUF_DEBUG - -#define UNIV_SEARCH_PERF_STAT -#define UNIV_SYNC_PERF_STAT -*/ -#define UNIV_LIGHT_MEM_DEBUG - -#define YYDEBUG 1 -/* -#define UNIV_SQL_DEBUG -#define UNIV_LOG_DEBUG -*/ - /* the above option prevents forcing of log to disk - at a buffer page write: it should be tested with this - option off; also some ibuf tests are suppressed */ -/* -#define UNIV_BASIC_LOG_DEBUG -*/ - /* the above option enables basic recovery debugging: - new allocated file pages are reset */ - -/* The debug version is slower, thus we may change the length of test loops -depending on the UNIV_DBC parameter */ -#ifdef UNIV_DEBUG -#define UNIV_DBC 1 -#else -#define UNIV_DBC 100 -#endif - -#ifndef UNIV_DEBUG -/* Definition for inline version */ - -#ifdef UNIV_VISUALC -#define UNIV_INLINE __inline -#elif defined(UNIV_GNUC) -#define UNIV_INLINE extern __inline__ -#endif - -#else -/* If we want to compile a noninlined version we use the following macro -definitions: */ - -#define UNIV_NONINL -#define UNIV_INLINE - -#endif /* UNIV_DEBUG */ -/* If the compiler does not know inline specifier, we use: */ -/* -#define UNIV_INLINE static -*/ - - -/* - MACHINE VERSION CONTROL - ======================= -*/ - -#ifdef UNIV_PENTIUM - -/* In a 32-bit computer word size is 4 */ -#define UNIV_WORD_SIZE 4 - -/* The following alignment is used in memory allocations in memory heap -management to ensure correct alignment for doubles etc. */ -#define UNIV_MEM_ALIGNMENT 8 - -/* The following alignment is used in aligning lints etc. */ -#define UNIV_WORD_ALIGNMENT UNIV_WORD_SIZE - -#endif - -/* - DATABASE VERSION CONTROL - ======================== -*/ - -/* The universal page size of the database */ -#define UNIV_PAGE_SIZE (2 * 8192)/* NOTE! Currently, this has to be a - power of 2 and divisible by - UNIV_MEM_ALIGNMENT */ - -/* Do non-buffered io in buffer pool read/write operations */ -#define UNIV_NON_BUFFERED_IO - -/* Maximum number of parallel threads in a parallelized operation */ -#define UNIV_MAX_PARALLELISM 32 - -/* - UNIVERSAL TYPE DEFINITIONS - ========================== -*/ - - -typedef unsigned char byte; - -/* An other basic type we use is unsigned long integer which is intended to be -equal to the word size of the machine. */ - -typedef unsigned long int ulint; - -typedef long int lint; - -/* The following type should be at least a 64-bit floating point number */ -typedef double utfloat; - -/* The 'undefined' value for a ulint */ -#define ULINT_UNDEFINED ((ulint)(-1)) - -/* The undefined 32-bit unsigned integer */ -#define ULINT32_UNDEFINED 0xFFFFFFFF - -/* Maximum value for a ulint */ -#define ULINT_MAX ((ulint)(-2)) - - -/* Definition of the boolean type */ -typedef ulint bool; - -#define TRUE 1 -#define FALSE 0 - -/* The following number as the length of a logical field means that the field -has the SQL NULL as its value. */ -#define UNIV_SQL_NULL ULINT_UNDEFINED - -#include <stdio.h> -#include "ut0dbg.h" -#include "ut0ut.h" -#include "db0err.h" - -#endif diff --git a/innobase/include/univoldmysql.i b/innobase/include/univoldmysql.i deleted file mode 100644 index 269b584d073..00000000000 --- a/innobase/include/univoldmysql.i +++ /dev/null @@ -1,181 +0,0 @@ -/*************************************************************************** -Version control for database, common definitions, and include files - -(c) 1994 - 1996 Innobase Oy - -Created 1/20/1994 Heikki Tuuri -****************************************************************************/ - -#ifndef univ_i -#define univ_i - -#define UNIV_INTEL -#define UNIV_PENTIUM -/* If UNIV_WINNT is not defined, we assume Windows 95 */ - -#define UNIV_WINNT -#define UNIV_WINNT4 - -#define UNIV_VISUALC - -/* DEBUG VERSION CONTROL - ===================== */ -/* Make a profiler version where mutex_fence does not use CPUID and therefore -is not totally safe. The sync-library must be recompiled before profiling. */ -/* -#define UNIV_PROFILE -*/ -/* When the following flag is defined, also mutex lock word reset to 0 -in mutex_exit is performed using a serializing instruction, which does not -allow speculative reads be performed before memory writes */ -/* -#define SYNC_SERIALIZE_MUTEX_RESET -*/ -/* Make a non-inline debug version */ - -#define UNIV_DEBUG -#define UNIV_MEM_DEBUG -#define UNIV_SYNC_DEBUG -#define UNIV_SEARCH_DEBUG - -#define UNIV_IBUF_DEBUG - -#define UNIV_SEARCH_PERF_STAT -#define UNIV_SYNC_PERF_STAT - - -#define UNIV_LIGHT_MEM_DEBUG - -#define YYDEBUG 1 -/* -#define UNIV_SQL_DEBUG -#define UNIV_LOG_DEBUG -*/ - /* the above option prevents forcing of log to disk - at a buffer page write: it should be tested with this - option off; also some ibuf tests are suppressed */ -/* -#define UNIV_BASIC_LOG_DEBUG -*/ - /* the above option enables basic recovery debugging: - new allocated file pages are reset */ - -/* The debug version is slower, thus we may change the length of test loops -depending on the UNIV_DBC parameter */ -#ifdef UNIV_DEBUG -#define UNIV_DBC 1 -#else -#define UNIV_DBC 100 -#endif - -#ifndef UNIV_DEBUG -/* Definition for inline version */ - -#ifdef UNIV_VISUALC -#define UNIV_INLINE __inline -#elif defined(UNIV_GNUC) -#define UNIV_INLINE extern __inline__ -#endif - -#else -/* If we want to compile a noninlined version we use the following macro -definitions: */ - -#define UNIV_NONINL -#define UNIV_INLINE - -#endif /* UNIV_DEBUG */ -/* If the compiler does not know inline specifier, we use: */ -/* -#define UNIV_INLINE static -*/ - - -/* - MACHINE VERSION CONTROL - ======================= -*/ - -#ifdef UNIV_PENTIUM - -/* In a 32-bit computer word size is 4 */ -#define UNIV_WORD_SIZE 4 - -/* The following alignment is used in memory allocations in memory heap -management to ensure correct alignment for doubles etc. */ -#define UNIV_MEM_ALIGNMENT 8 - -/* The following alignment is used in aligning lints etc. */ -#define UNIV_WORD_ALIGNMENT UNIV_WORD_SIZE - -#endif - -/* - DATABASE VERSION CONTROL - ======================== -*/ - -/* The universal page size of the database */ -#define UNIV_PAGE_SIZE 8192 /* NOTE! Currently, this has to be a - power of 2 and divisible by - UNIV_MEM_ALIGNMENT */ -/* 2-based logarithm of UNIV_PAGE_SIZE */ -#define UNIV_PAGE_SIZE_SHIFT 13 - -/* Do asynchronous io in buffer pool read/write operations */ -#ifdef UNIV_WINNT -#define UNIV_ASYNC_IO -#endif - -/* Do non-buffered io in buffer pool read/write operations */ -#define UNIV_NON_BUFFERED_IO - -/* Maximum number of parallel threads in a parallelized operation */ -#define UNIV_MAX_PARALLELISM 32 - -/* - UNIVERSAL TYPE DEFINITIONS - ========================== -*/ - -/* -typedef unsigned char byte; -*/ - -/* An other basic type we use is unsigned long integer which is intended to be -equal to the word size of the machine. */ - -typedef unsigned long int ulint; - -typedef long int lint; - -/* The following type should be at least a 64-bit floating point number */ -typedef double utfloat; - -/* The 'undefined' value for a ulint */ -#define ULINT_UNDEFINED ((ulint)(-1)) - -/* The undefined 32-bit unsigned integer */ -#define ULINT32_UNDEFINED 0xFFFFFFFF - -/* Maximum value for a ulint */ -#define ULINT_MAX ((ulint)(-2)) - -/* Definition of the boolean type */ -#ifndef bool -typedef ulint bool; -#endif - -#define TRUE 1 -#define FALSE 0 - -/* The following number as the length of a logical field means that the field -has the SQL NULL as its value. */ -#define UNIV_SQL_NULL ULINT_UNDEFINED - -#include <stdio.h> -#include "ut0dbg.h" -#include "ut0ut.h" -#include "db0err.h" - -#endif diff --git a/innobase/include/usr0sess.h b/innobase/include/usr0sess.h index 365f828ecfc..e277d801672 100644 --- a/innobase/include/usr0sess.h +++ b/innobase/include/usr0sess.h @@ -66,28 +66,6 @@ sess_open( byte* addr_buf, /* in: client address */ ulint addr_len); /* in: client address length */ /************************************************************************* -Closes a session, freeing the memory occupied by it. */ - -void -sess_close( -/*=======*/ - sess_t* sess); /* in, own: session object */ -/************************************************************************* -Raises an SQL error. */ - -void -sess_raise_error_low( -/*=================*/ - trx_t* trx, /* in: transaction */ - ulint err_no, /* in: error number */ - ulint type, /* in: more info of the error, or 0 */ - dict_table_t* table, /* in: dictionary table or NULL */ - dict_index_t* index, /* in: table index or NULL */ - dtuple_t* tuple, /* in: tuple to insert or NULL */ - rec_t* rec, /* in: record or NULL */ - char* err_str);/* in: arbitrary null-terminated error string, - or NULL */ -/************************************************************************* Closes a session, freeing the memory occupied by it, if it is in a state where it should be closed. */ @@ -117,16 +95,6 @@ sess_srv_msg_send_simple( ulint rel_kernel); /* in: SESS_RELEASE_KERNEL or SESS_NOT_RELEASE_KERNEL */ /*************************************************************************** -Processes a message from a client. NOTE: May release the kernel mutex -temporarily. */ - -void -sess_receive_msg_rel_kernel( -/*========================*/ - sess_t* sess, /* in: session */ - byte* str, /* in: message string */ - ulint len); /* in: message length */ -/*************************************************************************** When a command has been completed, this function sends the message about it to the client. */ @@ -136,17 +104,6 @@ sess_command_completed_message( sess_t* sess, /* in: session */ byte* msg, /* in: message buffer */ ulint len); /* in: message data length */ -/*********************************************************************** -Starts a new connection and a session, or starts a query based on a client -message. This is called by a SRV_COM thread. */ - -void -sess_process_cli_msg( -/*=================*/ - byte* str, /* in: message string */ - ulint len, /* in: string length */ - byte* addr, /* in: address string */ - ulint alen); /* in: address length */ /* The session handle. All fields are protected by the kernel mutex */ diff --git a/innobase/include/ut0rnd.ic b/innobase/include/ut0rnd.ic index e166a26fe86..5493c37404a 100644 --- a/innobase/include/ut0rnd.ic +++ b/innobase/include/ut0rnd.ic @@ -176,19 +176,19 @@ ut_fold_string( /* out: folded value */ char* str) /* in: null-terminated string */ { - #ifdef UNIV_DEBUG +#ifdef UNIV_DEBUG ulint i = 0; - #endif +#endif ulint fold = 0; ut_ad(str); while (*str != '\0') { - #ifdef UNIV_DEBUG +#ifdef UNIV_DEBUG i++; ut_a(i < 100); - #endif +#endif fold = ut_fold_ulint_pair(fold, (ulint)(*str)); str++; diff --git a/innobase/lock/lock0lock.c b/innobase/lock/lock0lock.c index 3541604a09a..deff4166ee4 100644 --- a/innobase/lock/lock0lock.c +++ b/innobase/lock/lock0lock.c @@ -3064,11 +3064,6 @@ retry: ut_a(strlen(lock_latest_err_buf) < 4100); - /* - sess_raise_error_low(trx, DB_DEADLOCK, lock->type_mode, table, - index, NULL, NULL, NULL); - */ - return(TRUE); } diff --git a/innobase/log/trash/log0trsh.c b/innobase/log/trash/log0trsh.c deleted file mode 100644 index 7f48118a0d1..00000000000 --- a/innobase/log/trash/log0trsh.c +++ /dev/null @@ -1,648 +0,0 @@ -/****************************************************** -Recovery - -(c) 1997 Innobase Oy - -Created 9/20/1997 Heikki Tuuri -*******************************************************/ - -#include "log0recv.h" - -#ifdef UNIV_NONINL -#include "log0recv.ic" -#endif - -#include "mem0mem.h" -#include "buf0buf.h" -#include "buf0flu.h" -#include "srv0srv.h" - -/* Size of block reads when the log groups are scanned forward to do -roll-forward */ -#define RECV_SCAN_SIZE (4 * UNIV_PAGE_SIZE) - -/* Size of block reads when the log groups are scanned backwards to synchronize -them */ -#define RECV_BACK_SCAN_SIZE (4 * UNIV_PAGE_SIZE) - -recv_sys_t* recv_sys = NULL; - -recv_recover_page(block->frame, block->space, block->offset); - -/************************************************************ -Creates the recovery system. */ - -void -recv_sys_create(void) -/*=================*/ -{ - ut_a(recv_sys == NULL); - - recv_sys = mem_alloc(sizeof(recv_t)); - - mutex_create(&(recv_sys->mutex)); - - recv_sys->hash = NULL; - recv_sys->heap = NULL; -} - -/************************************************************ -Inits the recovery system for a recovery operation. */ - -void -recv_sys_init(void) -/*===============*/ -{ - recv_sys->hash = hash_create(buf_pool_get_curr_size() / 64); - recv_sys->heap = mem_heap_create_in_buffer(256); -} - -/************************************************************ -Empties the recovery system. */ - -void -recv_sys_empty(void) -/*================*/ -{ - mutex_enter(&(recv_sys->mutex)); - - hash_free(recv_sys->hash); - mem_heap_free(recv_sys->heap); - - recv_sys->hash = NULL; - recv_sys->heap = NULL; - - mutex_exit(&(recv_sys->mutex)); -} - -/*********************************************************** -For recovery purposes copies the log buffer to a group to synchronize log -data. */ -static -void -recv_log_buf_flush( -/*===============*/ - log_group_t* group, /* in: log group */ - dulint start_lsn, /* in: start lsn of the log data in - the log buffer; must be divisible by - OS_FILE_LOG_BLOCK_SIZE */ - dulint end_lsn) /* in: end lsn of the log data in the - log buffer; must be divisible by - OS_FILE_LOG_BLOCK_SIZE */ -{ - ulint len; - - ut_ad(mutex_own(&(log_sys->mutex))); - - len = ut_dulint_minus(end_lsn, start_lsn); - - log_group_write_buf(LOG_RECOVER, group, log_sys->buf, len, start_lsn, - 0); -} - -/*********************************************************** -Compares two buffers containing log segments and determines the highest lsn -where they match, if any. */ -static -dulint -recv_log_bufs_cmp( -/*==============*/ - /* out: if no match found, ut_dulint_zero or - if start_lsn == LOG_START_LSN, returns - LOG_START_LSN; otherwise the highest matching - lsn */ - byte* recv_buf, /* in: buffer containing valid log data */ - byte* buf, /* in: buffer of data from a possibly - incompletely written log group */ - dulint start_lsn, /* in: buffer start lsn, must be divisible - by OS_FILE_LOG_BLOCK_SIZE and must be >= - LOG_START_LSN */ - dulint end_lsn, /* in: buffer end lsn, must be divisible - by OS_FILE_LOG_BLOCK_SIZE */ - dulint recovered_lsn) /* in: recovery succeeded up to this lsn */ -{ - ulint len; - ulint offset; - byte* log_block1; - byte* log_block2; - ulint no; - ulint data_len; - - ut_ad(ut_dulint_cmp(start_lsn, LOG_START_LSN) >= 0); - - if (ut_dulint_cmp(end_lsn, recovered_lsn) > 0) { - end_lsn = ut_dulint_align_up(recovered_lsn, - OS_FILE_LOG_BLOCK_SIZE); - } - - len = ut_dulint_minus(end_lsn, start_lsn); - - if (len == 0) { - - goto no_match; - } - - ut_ad(len % OS_FILE_LOG_BLOCK_SIZE == 0); - - log_block1 = recv_buf + len; - log_block2 = buf + len; - - for (;;) { - log_block1 -= OS_FILE_LOG_BLOCK_SIZE; - log_block2 -= OS_FILE_LOG_BLOCK_SIZE; - - no = log_block_get_hdr_no(log_block1); - ut_a(no == log_block_get_trl_no(log_block1)); - - if ((no == log_block_get_hdr_no(log_block2)) - && (no == log_block_get_trl_no(log_block2))) { - - /* Match found if the block is not corrupted */ - - data_len = log_block_get_data_len(log_block2); - - if (0 == ut_memcmp(log_block1 + LOG_BLOCK_DATA, - log_block2 + LOG_BLOCK_DATA, - data_len - LOG_BLOCK_DATA)) { - - /* Match found */ - - return(ut_dulint_add(start_lsn, - log_block2 - buf + data_len)); - } - } - - if (log_block1 == recv_buf) { - - /* No match found */ - - break; - } - } -no_match: - if (ut_dulint_cmp(start_lsn, LOG_START_LSN) == 0) { - - return(LOG_START_LSN); - } - - return(ut_dulint_zero); -} - -/************************************************************ -Copies a log segment from the most up-to-date log group to the other log -group, so that it contains the latest log data. */ -static -void -recv_copy_group( -/*============*/ - log_group_t* up_to_date_group, /* in: the most up-to-date - log group */ - log_group_t* group, /* in: copy to this log group */ - dulint_lsn recovered_lsn) /* in: recovery succeeded up - to this lsn */ -{ - dulint start_lsn; - dulint end_lsn; - dulint match; - byte* buf; - byte* buf1; - - ut_ad(mutex_own(&(log_sys->mutex))); - - if (0 == ut_dulint_cmp(LOG_START_LSN, recovered_lsn)) { - - return; - } - - ut_ad(RECV_BACK_SCAN_SIZE <= log_sys->buf_size); - - buf1 = mem_alloc(2 * RECV_BACK_SCAN_SIZE); - buf = ut_align(buf, RECV_BACK_SCAN_SIZE);); - - end_lsn = ut_dulint_align_up(recovered_lsn, RECV_BACK_SCAN_SIZE); - - match = ut_dulint_zero; - - for (;;) { - if (ut_dulint_cmp(ut_dulint_add(LOG_START_LSN, - RECV_BACK_SCAN_SIZE), end_lsn) >= 0) { - start_lsn = LOG_START_LSN; - } else { - start_lsn = ut_dulint_subtract(end_lsn, - RECV_BACK_SCAN_SIZE); - } - - log_group_read_log_seg(LOG_RECOVER, buf, group, start_lsn, - end_lsn); - log_group_read_log_seg(LOG_RECOVER, log_sys->buf, - up_to_date_group, start_lsn, end_lsn); - - match = recv_log_bufs_cmp(log_sys->buf, buf, start_lsn, - end_lsn, recovered_lsn); - - if (ut_dulint_cmp(match, recovered_lsn) != 0) { - recv_log_buf_flush(group, start_lsn, end_lsn); - } - - if (!ut_dulint_zero(match)) { - - mem_free(buf1); - - return; - } - - end_lsn = start_lsn; - } -} - -/************************************************************ -Copies a log segment from the most up-to-date log group to the other log -groups, so that they all contain the latest log data. Also writes the info -about the latest checkpoint to the groups, and inits the fields in the group -memory structs to up-to-date values. */ - -void -recv_synchronize_groups( -/*====================*/ - log_group_t* up_to_date_group, /* in: the most up-to-date - log group */ - dulint_lsn recovered_lsn, /* in: recovery succeeded up - to this lsn */ - log_group_t* max_checkpoint_group) /* in: the group with the most - recent checkpoint info */ -{ - log_group_t* group; - - ut_ad(mutex_own(&(log_sys->mutex))); - - group = UT_LIST_GET_FIRST(log_sys->log_groups); - - while (group) { - if (group != up_to_date_group) { - - /* Copy log data */ - - recv_copy_group(group, up_to_date_group, - recovered_lsn); - } - - if (group != max_checkpoint_group) { - - /* Copy the checkpoint info to the group */ - - log_group_checkpoint(group); - - mutex_exit(&(log_sys->mutex)); - - /* Wait for the checkpoint write to complete */ - rw_lock_s_lock(&(log_sys->checkpoint_lock)); - rw_lock_s_unlock(&(log_sys->checkpoint_lock)); - - mutex_enter(&(log_sys->mutex)); - } - - /* Update the fields in the group struct to correspond to - recovered_lsn */ - - log_group_set_fields(group, recovered_lsn); - - group = UT_LIST_GET_NEXT(log_groups, group); - } -} - -/************************************************************ -Looks for the maximum consistent checkpoint from the log groups. */ -static -ulint -recv_find_max_checkpoint( -/*=====================*/ - /* out: error code or DB_SUCCESS */ - log_group_t** max_group, /* out: max group */ - ulint* max_field) /* out: LOG_CHECKPOINT_1 or - LOG_CHECKPOINT_2 */ -{ - log_group_t* group; - dulint max_no; - dulint cp_no; - ulint field; - ulint fold; - byte* buf; - - ut_ad(mutex_own(&(log_sys->mutex))); - - /* Look for the latest checkpoint from the log groups */ - group = UT_LIST_GET_FIRST(log_sys->log_groups); - - checkpoint_no = ut_dulint_zero; - checkpoint_lsn = ut_dulint_zero; - *max_group = NULL; - - buf = log_sys->checkpoint_buf; - - while (group) { - group->state = LOG_GROUP_CORRUPTED; - - for (field = LOG_CHECKPOINT_1; field <= LOG_CHECKPOINT_2; - field += LOG_CHECKPOINT_2 - LOG_CHECKPOINT_1) { - - log_group_read_checkpoint_info(group, field); - - /* Check the consistency of the checkpoint info */ - fold = ut_fold_binary(buf, LOG_CHECKPOINT_CHECKSUM_1); - - if (fold != mach_read_from_4(buf - + LOG_CHECKPOINT_CHECKSUM_1)) { - goto not_consistent; - } - - fold = ut_fold_binary(buf + LOG_CHECKPOINT_LSN, - LOG_CHECKPOINT_CHECKSUM_2 - - LOG_CHECKPOINT_LSN); - if (fold != mach_read_from_4(buf - + LOG_CHECKPOINT_CHECKSUM_2)) { - goto not_consistent; - } - - group->state = LOG_GROUP_OK; - - group->lsn = mach_read_from_8(buf - + LOG_CHECKPOINT_LSN); - group->lsn_offset = mach_read_from_4(buf - + LOG_CHECKPOINT_OFFSET); - group->lsn_file_count = mach_read_from_4( - buf + LOG_CHECKPOINT_FILE_COUNT); - - cp_no = mach_read_from_8(buf + LOG_CHECKPOINT_NO); - - if (ut_dulint_cmp(cp_no, max_no) >= 0) { - *max_group = group; - *max_field = field; - max_no = cp_no; - } - - not_consistent: - } - - group = UT_LIST_GET_NEXT(log_groups, group); - } - - if (*max_group == NULL) { - - return(DB_ERROR); - } - - return(DB_SUCCESS); -} - -/*********************************************************** -Parses log records from a buffer and stores them to a hash table to wait -merging to file pages. If the hash table becomes too big, merges automatically -it to file pages. */ -static -bool -recv_parse_and_hash_log_recs( -/*=========================*/ - /* out: TRUE if limit_lsn has been reached */ - byte* buf, /* in: buffer containing a log segment or - garbage */ - ulint len, /* in: buffer length */ - dulint start_lsn, /* in: buffer start lsn */ - dulint limit_lsn, /* in: recover at least to this lsn */ - dulint* recovered_lsn) /* out: was able to parse up to this lsn */ -{ - -} - -/************************************************************ -Recovers from a checkpoint. When this function returns, the database is able -to start processing new user transactions, but the function -recv_recovery_from_checkpoint_finish should be called later to complete -the recovery and free the resources used in it. */ - -ulint -recv_recovery_from_checkpoint_start( -/*================================*/ - /* out: error code or DB_SUCCESS */ - dulint limit_lsn) /* in: recover up to this lsn if possible */ -{ - log_group_t* max_cp_group; - log_group_t* up_to_date_group; - ulint max_cp_field; - byte* buf; - ulint err; - dulint checkpoint_lsn; - dulint checkpoint_no; - dulint recovered_lsn; - dulint old_lsn; - dulint end_lsn; - dulint start_lsn; - bool finished; - dulint flush_start_lsn; - - mutex_enter(&(log_sys->mutex)); - - /* Look for the latest checkpoint from any of the log groups */ - - err = recv_find_max_checkpoint(&max_cp_group, &max_cp_field); - - if (err != DB_SUCCESS) { - mutex_exit(&(log_sys->mutex)); - - return(err); - } - - log_group_read_checkpoint_info(max_cp_group, max_cp_field); - - buf = log_sys->checkpoint_buf; - - checkpoint_lsn = mach_read_from_8(buf + LOG_CHECKPOINT_LSN); - checkpoint_no = mach_read_from_8(buf + LOG_CHECKPOINT_NO); - - if (ut_dulint_cmp(limit_lsn, checkpoint_lsn) < 0) { - mutex_exit(&(log_sys->mutex)); - - return(DB_ERROR); - } - - /* Start reading the log groups from the checkpoint lsn up. The - variable flush_start_lsn tells a lsn up to which the log is known - to be contiguously written in all log groups. */ - - recovered_lsn = checkpoint_lsn; - flush_start_lsn = ut_dulint_align_down(checkpoint_lsn, - OS_FILE_LOG_BLOCK_SIZE); - up_to_date_group = max_cp_group; - - ut_ad(RECV_SCAN_SIZE <= log_sys->buf_size); - - group = UT_LIST_GET_FIRST(log_sys->log_groups); - - while (group) { - finished = FALSE; - - if (group->state == LOG_GROUP_CORRUPTED) { - finished = TRUE; - } - - start_lsn = flush_start_lsn; - - while (!finished) { - end_lsn = ut_dulint_add(start_lsn, RECV_SCAN_SIZE); - - log_group_read_log_seg(LOG_RECOVER, log_sys->buf, - group, start_lsn, end_lsn); - old_lsn = recovered_lsn; - - finished = recv_parse_and_hash_log_recs(log_sys->buf, - RECV_SCAN_SIZE, start_lsn, - limit_lsn, &flush_start_lsn, - &recovered_lsn); - - if (ut_dulint_cmp(recovered_lsn, old_lsn) > 0) { - - /* We found a more up-to-date group */ - up_to_date_group = group; - } - - start_lsn = end_lsn; - } - - group = UT_LIST_GET_NEXT(log_groups, group); - } - - /* Delete possible corrupted or extra log records from all log - groups */ - - recv_truncate_groups(recovered_lsn); - - /* Synchronize the uncorrupted log groups to the most up-to-date log - group; we may also have to copy checkpoint info to groups */ - - log_sys->next_checkpoint_lsn = checkpoint_lsn; - log_sys->next_checkpoint_no = checkpoint_no; - - recv_synchronize_groups(up_to_date_group, _lsn, max_cp_group); - - log_sys->next_checkpoint_no = ut_dulint_add(checkpoint_no, 1); - - /* The database is now ready to start almost normal processing of user - transactions */ - - return(DB_SUCCESS); -} - -/************************************************************ -Completes recovery from a checkpoint. */ - -void -recv_recovery_from_checkpoint_finish(void) -/*======================================*/ -{ - /* Rollback the uncommitted transactions which have no user session */ - - trx_rollback_all_without_sess(); - - /* Merge the hashed log records */ - - recv_merge_hashed_log_recs(); - - /* Free the resources of the recovery system */ - - recv_sys_empty(); -} - -/**************************************************************** -Writes to the log a record about incrementing the row id counter. */ -UNIV_INLINE -void -log_write_row_id_incr_rec(void) -/*===========================*/ -{ - log_t* log = log_sys; - ulint data_len; - - mutex_enter(&(log->mutex)); - - data_len = (log->buf_free % OS_FILE_LOG_BLOCK_SIZE) + 1; - - if (data_len >= OS_FILE_LOG_BLOCK_SIZE - LOG_BLOCK_TRL_SIZE) { - - /* The string does not fit within the current log block - or the the block would become full */ - - mutex_exit(&(log->mutex)); - - log_write_row_id_incr_rec_slow(); - - return; - } - - *(log->buf + log->buf_free) = MLOG_INCR_ROW_ID | MLOG_SINGLE_REC_FLAG; - - log_block_set_data_len(ut_align_down(log->buf + log->buf_free, - OS_FILE_LOG_BLOCK_SIZE), - data_len); -#ifdef UNIV_LOG_DEBUG - log->old_buf_free = log->buf_free; - log->old_lsn = log->lsn; - log_check_log_recs(log->buf + log->buf_free, 1, log->lsn); -#endif - log->buf_free++; - - ut_ad(log->buf_free <= log->buf_size); - - UT_DULINT_INC(log->lsn); - - mutex_exit(&(log->mutex)); -} - -/**************************************************************** -Writes to the log a record about incrementing the row id counter. */ -static -void -log_write_row_id_incr_rec_slow(void) -/*================================*/ -{ - byte type; - - log_reserve_and_open(1); - - type = MLOG_INCR_ROW_ID | MLOG_SINGLE_REC_FLAG; - - log_write_low(&type, 1); - - log_close(); - - log_release(); -} - -/************************************************************************** -Parses and applies a log record MLOG_SET_ROW_ID. */ - -byte* -dict_hdr_parse_set_row_id( -/*======================*/ - /* out: end of log record or NULL */ - byte* ptr, /* in: buffer */ - byte* end_ptr,/* in: buffer end */ - page_t* page) /* in: page or NULL */ -{ - dulint dval; - - ptr = mach_dulint_parse_compressed(ptr, end_ptr, &dval); - - if (ptr == NULL) { - - return(NULL); - } - - if (!page) { - - return(ptr); - } - - mach_write_to_8(page + DICT_HDR + DICT_HDR_ROW_ID, dval); - - return(ptr); -} - diff --git a/innobase/mach/ts/makefile b/innobase/mach/ts/makefile deleted file mode 100644 index e9531e6ebe0..00000000000 --- a/innobase/mach/ts/makefile +++ /dev/null @@ -1,12 +0,0 @@ - -include ..\..\makefile.i - -tsmach: ..\mach.lib tsmach.c - $(CCOM) $(CFL) -I.. -I..\.. ..\mach.lib ..\..\ut.lib ..\..\os.lib tsmach.c $(LFL) - - - - - - - diff --git a/innobase/mach/ts/tsmach.c b/innobase/mach/ts/tsmach.c deleted file mode 100644 index a4b67227d20..00000000000 --- a/innobase/mach/ts/tsmach.c +++ /dev/null @@ -1,158 +0,0 @@ -/************************************************************************ -The test module for the machine-dependent utilities - -(c) 1995 Innobase Oy - -Created 11/28/1995 Heikki Tuuri -*************************************************************************/ - -#include "../mach0data.h" - -byte arr[4000000]; - - -/********************************************************************* -Test for ulint write and read. */ - -void -test1(void) -/*=======*/ -{ - ulint a, i, j; - ulint tm, oldtm; - - printf("-------------------------------------------\n"); - printf("TEST 1. Speed test of ulint read and write \n"); - - a = 0; - - oldtm = ut_clock(); - - for (j = 0; j < 100; j++) { - for (i = 0; i < 10000; i++) { - - a += mach_read_from_4(arr + i * 4); - } - } - - tm = ut_clock(); - - printf("Wall clock time for read of %lu ulints %lu millisecs\n", - j * i, tm - oldtm); - - oldtm = ut_clock(); - - for (j = 0; j < 100; j++) { - for (i = 0; i < 10000; i++) { - - a += mach_read(arr + i * 4); - } - } - - tm = ut_clock(); - - printf("Wall clock time for read of %lu ulints %lu millisecs\n", - j * i, tm - oldtm); - - oldtm = ut_clock(); - - for (j = 0; j < 100; j++) { - for (i = 0; i < 10000; i++) { - - a += mach_read_from_4(arr + i * 4 + 1); - } - } - - tm = ut_clock(); - - printf("Wall clock time for read of %lu ulints %lu millisecs\n", - j * i, tm - oldtm); - oldtm = ut_clock(); - - for (j = 0; j < 100; j++) { - for (i = 0; i < 10000; i++) { - - a += mach_read(arr + i * 4 + 1); - } - } - - tm = ut_clock(); - - printf("Wall clock time for read of %lu ulints %lu millisecs\n", - j * i, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 1000000; i++) { - - a += mach_read_from_4(arr + i * 4); - } - - tm = ut_clock(); - - printf("Wall clock time for read of %lu ulints %lu millisecs\n", - i, tm - oldtm); - oldtm = ut_clock(); - - for (i = 0; i < 1000000; i++) { - - a += mach_read(arr + i * 4); - } - - tm = ut_clock(); - - printf("Wall clock time for read of %lu ulints %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - for (j = 0; j < 100; j++) { - for (i = 0; i < 10000; i++) { - - a += mach_read_from_2(arr + i * 2); - } - } - - tm = ut_clock(); - - printf("Wall clock time for read of %lu 16-bit ints %lu millisecs\n", - j * i, tm - oldtm); -} - -/********************************************************************* -Test for ulint write and read. */ - -void -test2(void) -/*=======*/ -{ - ulint a[2]; - - printf("-------------------------------------------\n"); - printf("TEST 2. Correctness test of ulint read and write \n"); - - mach_write_to_4((byte*)&a, 737237727); - - ut_a(737237727 == mach_read_from_4((byte*)&a)); - - mach_write_to_2((byte*)&a, 7372); - - ut_a(7372 == mach_read_from_2((byte*)&a)); - - mach_write_to_1((byte*)&a, 27); - - ut_a(27 == mach_read_from_1((byte*)&a)); - - mach_write((byte*)&a, 737237727); - - ut_a(737237727 == mach_read((byte*)&a)); -} - -void -main(void) -{ - test1(); - test2(); - - printf("TEST SUCCESSFULLY COMPLETED!\n"); -} diff --git a/innobase/mem/mem0dbg.c b/innobase/mem/mem0dbg.c index 004197a5b8e..5831dc4c451 100644 --- a/innobase/mem/mem0dbg.c +++ b/innobase/mem/mem0dbg.c @@ -408,12 +408,12 @@ mem_heap_validate_or_print( ulint total_len = 0; ulint block_count = 0; ulint phys_len = 0; - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG ulint len; byte* field; byte* user_field; ulint check_field; - #endif +#endif /* Pessimistically, we set the parameters to error values */ if (us_size != NULL) { @@ -451,7 +451,7 @@ mem_heap_validate_or_print( return; } - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG /* We can trace the fields of the block only in the debug version */ if (print) { @@ -518,7 +518,7 @@ mem_heap_validate_or_print( return; } - #endif +#endif block = UT_LIST_GET_NEXT(list, block); block_count++; @@ -735,7 +735,7 @@ mem_all_freed(void) /*===============*/ /* out: TRUE if no heaps exist */ { - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG mem_hash_node_t* node; ulint heap_count = 0; @@ -765,14 +765,14 @@ mem_all_freed(void) return(FALSE); } - #else +#else printf( "Sorry, non-debug version cannot check if all memory is freed.\n"); return(FALSE); - #endif +#endif } /********************************************************************* @@ -783,7 +783,7 @@ mem_validate_no_assert(void) /*========================*/ /* out: TRUE if error */ { - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG mem_hash_node_t* node; ulint n_heaps = 0; @@ -844,13 +844,13 @@ mem_validate_no_assert(void) return(error); - #else +#else printf("Sorry, non-debug version cannot validate dynamic memory\n"); return(FALSE); - #endif +#endif } /**************************************************************** diff --git a/innobase/mem/mem0mem.c b/innobase/mem/mem0mem.c index 94cf85dfd63..6de8d0c5f20 100644 --- a/innobase/mem/mem0mem.c +++ b/innobase/mem/mem0mem.c @@ -294,13 +294,13 @@ mem_heap_block_free( init_block = block->init_block; block->magic_n = MEM_FREED_BLOCK_MAGIC_N; - #ifdef UNIV_MEM_DEBUG +#ifdef UNIV_MEM_DEBUG /* In the debug version we set the memory to a random combination of hex 0xDE and 0xAD. */ mem_erase_buf((byte*)block, len); - #endif +#endif if (init_block) { /* Do not have to free: do nothing */ diff --git a/innobase/mem/ts/makefile b/innobase/mem/ts/makefile deleted file mode 100644 index 0f6855322ce..00000000000 --- a/innobase/mem/ts/makefile +++ /dev/null @@ -1,12 +0,0 @@ - -include ..\..\makefile.i - -tsmem: ..\mem.lib tsmem.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\mem.lib ..\..\btr.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\os.lib tsmem.c $(LFL) - - - - - - - diff --git a/innobase/mem/ts/tsmem.c b/innobase/mem/ts/tsmem.c deleted file mode 100644 index 4a108251673..00000000000 --- a/innobase/mem/ts/tsmem.c +++ /dev/null @@ -1,497 +0,0 @@ -/************************************************************************ -The test module for the memory management of Innobase - -(c) 1994, 1995 Innobase Oy - -Created 6/10/1994 Heikki Tuuri -*************************************************************************/ - -#include "../mem0mem.h" -#include "sync0sync.h" -#include "ut0rnd.h" - -mem_heap_t* heap_arr[1200]; - -byte* buf_arr[10000]; -ulint rnd_arr[10000]; - - -#ifdef UNIV_DEBUG -/********************************************************************* -Debug version test. */ - -void -test1(void) -/*=======*/ -{ - mem_heap_t* heap_1, *heap_2; - byte* buf_1, *buf_2, *buf_3; - byte check; - bool error; - ulint i; - ulint j; - ulint sum; - ulint user_size; - ulint phys_size, phys_size_1, phys_size_2; - ulint n_blocks; - ulint p; - byte block[1024]; - byte* top_1, *top_2; - - /* For this test to work the memory alignment must be - even (presumably a reasonable assumption) */ - ut_a(0 == (UNIV_MEM_ALIGNMENT & 1)); - - printf("-------------------------------------------\n"); - printf("TEST 1. Basic test \n"); - - heap_1 = mem_heap_create(0); - - buf_1 = mem_heap_alloc(heap_1, 11); - - heap_2 = mem_heap_create(0); - - buf_2 = mem_heap_alloc(heap_1, 15); - - /* Test that the field is properly initialized */ - for (i = 0; i < 11; i++) { - ut_a((*(buf_1 + i) == 0xBA) || (*(buf_1 + i) == 0xBE)); - } - - check = *(buf_1 + 11); - - mem_validate(); - - /* Make an advertent error in the heap */ - (*(buf_1 + 11))++; - - error = mem_validate_no_assert(); - - ut_a(error); - - /* Fix the error in heap before freeing */ - *(buf_1 + 11) = check; - - mem_print_info(); - - /* Free the top buffer buf_2 */ - mem_heap_free_top(heap_1, 15); - - /* Test that the field is properly erased */ - for (i = 0; i < 15; i++) { - ut_a((*(buf_2 + i) == 0xDE) || (*(buf_2 + i) == 0xAD)); - } - - /* Test that a new buffer is allocated from the same position - as buf_2 */ - buf_3 = mem_heap_alloc(heap_1, 15); - - ut_a(buf_3 == buf_2); - - mem_heap_free(heap_1); - - /* Test that the field is properly erased */ - for (i = 0; i < 11; i++) { - ut_a((*(buf_1 + i) == 0xDE) || (*(buf_1 + i) == 0xAD)); - } - - mem_validate(); - - mem_print_info(); - - printf("-------------------------------------------\n"); - printf("TEST 2. Test of massive allocation and freeing\n"); - - sum = 0; - for (i = 0; i < 10000; i++) { - - j = ut_rnd_gen_ulint() % 16 + 15; - - sum = sum + j; - - buf_1 = mem_heap_alloc(heap_2, j); - rnd_arr[i] = j; - - buf_arr[i] = buf_1; - - ut_a(buf_1 == mem_heap_get_top(heap_2, j)); - } - - mem_heap_validate_or_print(heap_2, NULL, FALSE, &error, &user_size, - &phys_size_1, - &n_blocks); - - ut_a(!error); - ut_a(user_size == sum); - - (*(buf_1 - 1))++; - - ut_a(mem_validate_no_assert()); - - (*(buf_1 - 1))--; - - mem_print_info(); - - - for (p = 10000; p > 0 ; p--) { - - j = rnd_arr[p - 1]; - - ut_a(buf_arr[p - 1] == mem_heap_get_top(heap_2, j)); - mem_heap_free_top(heap_2, j); - } - - mem_print_info(); - - mem_heap_free(heap_2); - - mem_print_info(); - - printf("-------------------------------------------\n"); - printf("TEST 3. More tests on the validating \n"); - - heap_1 = mem_heap_create(UNIV_MEM_ALIGNMENT * 20); - - buf_1 = mem_heap_alloc(heap_1, UNIV_MEM_ALIGNMENT * 20); - - mem_heap_validate_or_print(heap_1, NULL, FALSE, &error, &user_size, - &phys_size_1, - &n_blocks); - - ut_a((ulint)(buf_1 - (byte*)heap_1) == (MEM_BLOCK_HEADER_SIZE - + MEM_FIELD_HEADER_SIZE)); - - mem_validate(); - - mem_print_info(); - - ut_a(user_size == UNIV_MEM_ALIGNMENT * 20); - ut_a(phys_size_1 == (ulint)(ut_calc_align(MEM_FIELD_HEADER_SIZE - + UNIV_MEM_ALIGNMENT * 20 - + MEM_FIELD_TRAILER_SIZE, - UNIV_MEM_ALIGNMENT) - + MEM_BLOCK_HEADER_SIZE)); - - ut_a(n_blocks == 1); - - buf_2 = mem_heap_alloc(heap_1, UNIV_MEM_ALIGNMENT * 3 - 1); - - mem_heap_validate_or_print(heap_1, NULL, FALSE, &error, - &user_size, &phys_size_2, - &n_blocks); - - printf("Physical size of the heap %ld\n", phys_size_2); - - ut_a(!error); - ut_a(user_size == UNIV_MEM_ALIGNMENT * 23 - 1); - ut_a(phys_size_2 == (ulint) (phys_size_1 - + ut_calc_align(MEM_FIELD_HEADER_SIZE - + phys_size_1 * 2 - + MEM_FIELD_TRAILER_SIZE, - UNIV_MEM_ALIGNMENT) - + MEM_BLOCK_HEADER_SIZE)); - - ut_a(n_blocks == 2); - - buf_3 = mem_heap_alloc(heap_1, UNIV_MEM_ALIGNMENT * 3 + 5); - - ut_a((ulint)(buf_3 - buf_2) == ut_calc_align( - (UNIV_MEM_ALIGNMENT * 3 - + MEM_FIELD_TRAILER_SIZE), - UNIV_MEM_ALIGNMENT) - + MEM_FIELD_HEADER_SIZE); - - - ut_memcpy(buf_3, buf_2, UNIV_MEM_ALIGNMENT * 3); - - mem_heap_validate_or_print(heap_1, NULL, FALSE, &error, - &user_size, &phys_size, - &n_blocks); - - ut_a(!error); - ut_a(user_size == UNIV_MEM_ALIGNMENT * 26 + 4); - ut_a(phys_size == phys_size_2); - ut_a(n_blocks == 2); - - - /* Make an advertent error to buf_3 */ - - (*(buf_3 - 1))++; - - mem_heap_validate_or_print(heap_1, NULL, FALSE, &error, - &user_size, &phys_size, - &n_blocks); - - ut_a(error); - ut_a(user_size == 0); - ut_a(phys_size == 0); - ut_a(n_blocks == 0); - - /* Fix the error and make another */ - - (*(buf_3 - 1))--; - (*(buf_3 + UNIV_MEM_ALIGNMENT * 3 + 5))++; - - mem_heap_validate_or_print(heap_1, NULL, FALSE, &error, - &user_size, &phys_size, - &n_blocks); - - ut_a(error); - - (*(buf_3 + UNIV_MEM_ALIGNMENT * 3 + 5))--; - - buf_1 = mem_heap_alloc(heap_1, UNIV_MEM_ALIGNMENT + 4); - - ut_a((ulint)(buf_1 - buf_3) == ut_calc_align(UNIV_MEM_ALIGNMENT * 3 + 5 - + MEM_FIELD_TRAILER_SIZE , - UNIV_MEM_ALIGNMENT) - + MEM_FIELD_HEADER_SIZE); - - - mem_heap_validate_or_print(heap_1, NULL, FALSE, &error, - &user_size, &phys_size, - &n_blocks); - - ut_a(!error); - ut_a(user_size == UNIV_MEM_ALIGNMENT * 27 + 8); - ut_a(phys_size == phys_size_2); - ut_a(n_blocks == 2); - - - mem_print_info(); - - mem_heap_free(heap_1); - - printf("-------------------------------------------\n"); - printf("TEST 4. Test of massive allocation \n"); - printf("of heaps to test the hash table\n"); - - for (i = 0; i < 500; i++) { - heap_arr[i] = mem_heap_create(i); - buf_2 = mem_heap_alloc(heap_arr[i], 2 * i); - } - - mem_validate(); - - for (i = 0; i < 500; i++) { - mem_heap_free(heap_arr[i]); - } - - mem_validate(); - - mem_print_info(); - - /* Validating a freed heap should generate an error */ - - mem_heap_validate_or_print(heap_1, NULL, FALSE, &error, - NULL, NULL, NULL); - - ut_a(error); - - printf("-------------------------------------------\n"); - printf("TEST 5. Test of mem_alloc and mem_free \n"); - - buf_1 = mem_alloc(11100); - buf_2 = mem_alloc(23); - - ut_memcpy(buf_2, buf_1, 23); - - mem_validate(); - - mem_print_info(); - - mem_free(buf_1); - mem_free(buf_2); - - mem_validate(); - - printf("-------------------------------------------\n"); - printf("TEST 6. Test of mem_heap_print \n"); - - heap_1 = mem_heap_create(0); - - buf_1 = mem_heap_alloc(heap_1, 7); - - ut_memcpy(buf_1, "Pascal", 7); - - for (i = 0; i < 10; i++) { - buf_1 = mem_heap_alloc(heap_1, 6); - ut_memcpy(buf_1, "Cobol", 6); - } - - printf("A heap with 1 Pascal and 10 Cobol's\n"); - mem_heap_print(heap_1); - - for (i = 0; i < 10; i++) { - mem_heap_free_top(heap_1, 6); - } - - printf("A heap with 1 Pascal and 0 Cobol's\n"); - mem_heap_print(heap_1); - - ut_a(mem_all_freed() == FALSE); - - mem_heap_free(heap_1); - - ut_a(mem_all_freed() == TRUE); - - mem_print_info(); - - printf("-------------------------------------------\n"); - printf("TEST 7. Test of mem_heap_fast_create \n"); - - heap_1 = mem_heap_fast_create(1024, block); - - buf_1 = mem_heap_alloc(heap_1, 7); - - ut_memcpy(buf_1, "Pascal", 7); - - for (i = 0; i < 1000; i++) { - buf_1 = mem_heap_alloc(heap_1, 6); - ut_memcpy(buf_1, "Cobol", 6); - } - - for (i = 0; i < 1000; i++) { - mem_heap_free_top(heap_1, 6); - } - - ut_a(mem_all_freed() == FALSE); - - mem_heap_free(heap_1); - - ut_a(mem_all_freed() == TRUE); - - mem_print_info(); - - printf("-------------------------------------------\n"); - printf("TEST 8. Test of heap top freeing \n"); - - heap_1 = mem_heap_fast_create(1024, block); - - top_1 = mem_heap_get_heap_top(heap_1); - - buf_1 = mem_heap_alloc(heap_1, 7); - - ut_memcpy(buf_1, "Pascal", 7); - - for (i = 0; i < 500; i++) { - buf_1 = mem_heap_alloc(heap_1, 6); - ut_memcpy(buf_1, "Cobol", 6); - } - - top_2 = mem_heap_get_heap_top(heap_1); - - for (i = 0; i < 500; i++) { - buf_1 = mem_heap_alloc(heap_1, 6); - ut_memcpy(buf_1, "Cobol", 6); - } - - mem_heap_free_heap_top(heap_1, top_2); - - mem_heap_free_heap_top(heap_1, top_1); - - ut_a(mem_all_freed() == FALSE); - - for (i = 0; i < 500; i++) { - buf_1 = mem_heap_alloc(heap_1, 6); - ut_memcpy(buf_1, "Cobol", 6); - - } - - mem_heap_empty(heap_1); - - for (i = 0; i < 500; i++) { - buf_1 = mem_heap_alloc(heap_1, 6); - ut_memcpy(buf_1, "Cobol", 6); - - } - - mem_heap_free(heap_1); - - ut_a(mem_all_freed() == TRUE); - - mem_print_info(); - -} -#endif /* UNIV_DEBUG */ - -/**************************************************************** -Allocation speed test. */ - -void -test2(void) -/*=======*/ -{ - mem_heap_t* heap; - ulint tm, oldtm; - ulint i; - byte* buf; - byte block[512]; - - printf("-------------------------------------------\n"); - printf("TEST B1. Test of speed \n"); - - oldtm = ut_clock(); - - for (i = 0; i < 10000 * UNIV_DBC * UNIV_DBC; i++) { - heap = mem_heap_create(500); - mem_heap_free(heap); - } - - tm = ut_clock(); - - printf("Time for %ld heap create-free pairs %ld millisecs.\n", - i, tm - oldtm); - - - oldtm = ut_clock(); - - for (i = 0; i < 10000 * UNIV_DBC * UNIV_DBC; i++) { - heap = mem_heap_fast_create(512, block); - mem_heap_free(heap); - } - - tm = ut_clock(); - - printf("Time for %ld heap fast-create-free pairs %ld millisecs.\n", - i, tm - oldtm); - - - heap = mem_heap_create(500); - - oldtm = ut_clock(); - - for (i = 0; i < 10000 * UNIV_DBC * UNIV_DBC; i++) { - buf = mem_heap_alloc(heap, 50); - mem_heap_free_top(heap, 50); - } - - tm = ut_clock(); - - printf("Time for %ld heap alloc-free-top pairs %ld millisecs.\n", - i, tm - oldtm); - - mem_heap_free(heap); -} - - -void -main(void) -{ - sync_init(); - mem_init(2500000); - - #ifdef UNIV_DEBUG - - test1(); - - #endif - - test2(); - - ut_ad(sync_all_freed()); - - ut_ad(mem_all_freed()); - - printf("TEST SUCCESSFULLY COMPLETED!\n"); -} diff --git a/innobase/mtr/ts/makefile b/innobase/mtr/ts/makefile deleted file mode 100644 index 3a155fb1401..00000000000 --- a/innobase/mtr/ts/makefile +++ /dev/null @@ -1,8 +0,0 @@ - - - -include ..\..\makefile.i - -tsmtr: ..\mtr.lib tsmtr.c - $(CCOM) $(CFL) -I.. -I..\.. ..\mtr.lib ..\..\dyn.lib ..\..\log.lib ..\..\mach.lib ..\..\buf.lib ..\..\fil.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsmtr.c $(LFL) - diff --git a/innobase/mtr/ts/tsbuf.c b/innobase/mtr/ts/tsbuf.c deleted file mode 100644 index a2a18d7afaf..00000000000 --- a/innobase/mtr/ts/tsbuf.c +++ /dev/null @@ -1,531 +0,0 @@ -/************************************************************************ -The test module for the file system and buffer manager - -(c) 1995 Innobase Oy - -Created 11/16/1995 Heikki Tuuri -*************************************************************************/ - -#include "os0thread.h" -#include "os0file.h" -#include "ut0ut.h" -#include "sync0sync.h" -#include "mem0mem.h" -#include "fil0fil.h" -#include "..\buf0buf.h" -#include "..\buf0flu.h" -#include "..\buf0lru.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[5]; - - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************ -Creates the test database files. */ - -void -create_db(void) -/*===========*/ -{ - ulint i; - buf_block_t* block; - byte* frame; - ulint j; - ulint tm, oldtm; - - oldtm = ut_clock(); - - for (i = 0; i < 1; i++) { - for (j = 0; j < 4096; j++) { - block = buf_page_create(i, j); - - frame = buf_block_get_frame(block); - - rw_lock_x_lock(buf_page_get_lock(block)); - - if (j > 0) { - fil_page_set_prev(frame, j - 1); - } else { - fil_page_set_prev(frame, 0); - } - - if (j < 4095) { - fil_page_set_next(frame, j + 1); - } else { - fil_page_set_next(frame, 0); - } - - *((ulint*)(frame + 16)) = j; - - buf_page_note_modification(block); - - rw_lock_x_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - -/* buf_LRU_print(); */ - - /* Flush the pool of dirty pages by reading low-offset pages */ - for (i = 0; i < 1000; i++) { - - block = buf_page_get(0, i, NULL); - - frame = buf_block_get_frame(block); - - rw_lock_s_lock(buf_page_get_lock(block)); - - ut_a(*((ulint*)(frame + 16)) == i); - - rw_lock_s_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - -/* buf_LRU_print(); */ - - os_thread_sleep(1000000); - - ut_a(buf_all_freed()); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[10]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - name[0] = 't'; - name[1] = 's'; - name[2] = 'f'; - name[3] = 'i'; - name[4] = 'l'; - name[5] = 'e'; - name[8] = '\0'; - - for (k = 0; k < 1; k++) { - for (i = 0; i < 1; i++) { - - name[6] = (char)(k + (ulint)'a'); - name[7] = (char)(i + (ulint)'a'); - - files[i] = os_file_create("j:\\tsfile4", OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - "j:\\tsfile4", OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_set_size(files[i], 4096 * 8192, 0); - ut_a(ret); - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create("noname", k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create("j:\\tsfile4", 4096, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Reads the test database files. */ - -void -test1(void) -/*=======*/ -{ - ulint i, j, k; - buf_block_t* block; - byte* frame; - ulint tm, oldtm; - - buf_flush_batch(BUF_FLUSH_LIST, 1000); - - os_thread_sleep(1000000); - - buf_all_freed(); - - oldtm = ut_clock(); - - for (k = 0; k < 1; k++) { - for (i = 0; i < 1; i++) { - for (j = 0; j < 409; j++) { - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - rw_lock_s_lock(buf_page_get_lock(block)); - - ut_a(*((ulint*)(frame + 16)) == j); - - rw_lock_s_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - } - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - -} - -/************************************************************************ -Reads the test database files. */ - -void -test2(void) -/*=======*/ -{ - ulint i, j, k, rnd; - buf_block_t* block; - byte* frame; - ulint tm, oldtm; - - oldtm = ut_clock(); - - rnd = 123; - - for (k = 0; k < 100; k++) { - rnd += 23651; - rnd = rnd % 4096; - - i = rnd / 4096; - j = rnd % 2048; - - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - rw_lock_s_lock(buf_page_get_lock(block)); - - ut_a(*((ulint*)(frame + 16)) == j); - - rw_lock_s_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - - tm = ut_clock(); - printf("Wall clock time for random read %lu milliseconds\n", - tm - oldtm); -} - -/************************************************************************ -Reads the test database files. */ - -void -test4(void) -/*=======*/ -{ - ulint i, j, k, rnd; - buf_block_t* block; - byte* frame; - ulint tm, oldtm; - - /* Flush the pool of high-offset pages */ - for (i = 0; i < 1000; i++) { - - block = buf_page_get(0, i, NULL); - - frame = buf_block_get_frame(block); - - rw_lock_s_lock(buf_page_get_lock(block)); - - ut_a(*((ulint*)(frame + 16)) == i); - - rw_lock_s_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - - printf("Test starts\n"); - - oldtm = ut_clock(); - - rnd = 123; - - for (k = 0; k < 400; k++) { - - rnd += 4357; - - i = 0; - j = 1001 + rnd % 3000; - - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - rw_lock_s_lock(buf_page_get_lock(block)); - - ut_a(*((ulint*)(frame + 16)) == j); - - rw_lock_s_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - - tm = ut_clock(); - printf( - "Wall clock time for %lu random no read-ahead %lu milliseconds\n", - k, tm - oldtm); - - /* Flush the pool of high-offset pages */ - for (i = 0; i < 1000; i++) { - - block = buf_page_get(0, i, NULL); - - frame = buf_block_get_frame(block); - - rw_lock_s_lock(buf_page_get_lock(block)); - - ut_a(*((ulint*)(frame + 16)) == i); - - rw_lock_s_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - - printf("Test starts\n"); - - oldtm = ut_clock(); - - rnd = 123; - - for (k = 0; k < 400; k++) { - - rnd += 4357; - - i = 0; - j = 1001 + rnd % 400; - - block = buf_page_get(i, j, NULL); - - frame = buf_block_get_frame(block); - - rw_lock_s_lock(buf_page_get_lock(block)); - - ut_a(*((ulint*)(frame + 16)) == j); - - rw_lock_s_unlock(buf_page_get_lock(block)); - - buf_page_release(block); - } - - tm = ut_clock(); - printf( - "Wall clock time for %lu random read-ahead %lu milliseconds\n", - k, tm - oldtm); - -} - -/************************************************************************ -Tests speed of CPU algorithms. */ - -void -test3(void) -/*=======*/ -{ - ulint i, j; - buf_block_t* block; - ulint tm, oldtm; - - for (i = 0; i < 400; i++) { - - block = buf_page_get(0, i, NULL); - - buf_page_release(block); - } - - os_thread_sleep(2000000); - - oldtm = ut_clock(); - - for (j = 0; j < 500; j++) { - for (i = 0; i < 200; i++) { - - block = buf_page_get(0, i, NULL); - -/* - rw_lock_s_lock(buf_page_get_lock(block)); - - rw_lock_s_unlock(buf_page_get_lock(block)); -*/ - - buf_page_release(block); - - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu page get-release %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (j = 0; j < 500; j++) { - for (i = 0; i < 200; i++) { - - buf_block_get(block); -/* - rw_lock_s_lock(buf_page_get_lock(block)); - - rw_lock_s_unlock(buf_page_get_lock(block)); -*/ - buf_page_release(block); - } - } - - tm = ut_clock(); - printf("Wall clock time for %lu block get-release %lu milliseconds\n", - i * j, tm - oldtm); - - - oldtm = ut_clock(); - - for (i = 0; i < 100000; i++) { - block = buf_block_alloc(); - buf_block_free(block); - } - - tm = ut_clock(); - printf("Wall clock time for %lu block alloc-free %lu milliseconds\n", - i, tm - oldtm); - - ha_print_info(buf_pool->page_hash); -} - -/************************************************************************ -Frees the spaces in the file system. */ - -void -free_system(void) -/*=============*/ -{ - ulint i; - - for (i = 0; i < 1; i++) { - fil_space_free(i); - } -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - ulint n; - - oldtm = ut_clock(); - - os_aio_init(160, 5); - sync_init(); - mem_init(); - fil_init(26); /* Allow 25 open files at a time */ - buf_pool_init(1000, 1000); - - buf_validate(); - - ut_a(fil_validate()); - - create_files(); - - create_db(); - - buf_validate(); - - test1(); - - test3(); - - test4(); - - test2(); - - buf_validate(); - - n = buf_flush_batch(BUF_FLUSH_LIST, 500); - - os_thread_sleep(1000000); - - buf_all_freed(); - - free_system(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/mtr/ts/tsmtr.c b/innobase/mtr/ts/tsmtr.c deleted file mode 100644 index 42997cd2699..00000000000 --- a/innobase/mtr/ts/tsmtr.c +++ /dev/null @@ -1,158 +0,0 @@ -/************************************************************************ -The test module for the mini-transaction utilities - -(c) 1995 Innobase Oy - -Created 11/26/1995 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "sync0rw.h" -#include "mem0mem.h" -#include "log0log.h" -#include "..\mtr0mtr.h" -#include "..\mtr0log.h" - -rw_lock_t rwl[MTR_BUF_MEMO_SIZE]; - -/********************************************************************* -Test for mtr buffer */ - -void -test1(void) -/*=======*/ -{ - ulint i; - mtr_t mtr; - - printf("-------------------------------------------\n"); - printf("MTR-TEST 1. Test of mtr buffer\n"); - - mtr_start(&mtr); - - for (i = 0; i < MTR_BUF_MEMO_SIZE; i++) { - rw_lock_create(rwl + i); - } - - for (i = 0; i < MTR_BUF_MEMO_SIZE; i++) { - rw_lock_s_lock(rwl + i); - mtr_memo_push(&mtr, rwl + i, MTR_MEMO_S_LOCK); - } - - mtr_commit(&mtr); - - rw_lock_list_print_info(); - ut_ad(rw_lock_n_locked() == 0); - -} - -/************************************************************************ -Speed test function. */ -void -speed_mtr(void) -/*===========*/ -{ - mtr_t mtr; - - mtr_start(&mtr); - - mtr_s_lock(rwl, &mtr); - mtr_s_lock(rwl + 1, &mtr); - mtr_s_lock(rwl + 2, &mtr); - - mtr_commit(&mtr); -} - -/************************************************************************ -Speed test function without mtr. */ -void -speed_no_mtr(void) -/*===========*/ -{ - rw_lock_s_lock(rwl); - rw_lock_s_lock(rwl + 1); - rw_lock_s_lock(rwl + 2); - rw_lock_s_unlock(rwl + 2); - rw_lock_s_unlock(rwl + 1); - rw_lock_s_unlock(rwl); -} - -/************************************************************************ -Speed test function. */ - -void -test2(void) -/*======*/ -{ - ulint tm, oldtm; - ulint i, j; - mtr_t mtr; - byte buf[50]; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - speed_mtr(); - } - - tm = ut_clock(); - printf("Wall clock time for %lu mtrs %lu milliseconds\n", - i, tm - oldtm); - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - speed_no_mtr(); - } - - tm = ut_clock(); - printf("Wall clock time for %lu no-mtrs %lu milliseconds\n", - i, tm - oldtm); - - oldtm = ut_clock(); - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - for (j = 0; j < 250; j++) { - mlog_catenate_ulint(&mtr, 5, MLOG_1BYTE); - mlog_catenate_ulint(&mtr, i, MLOG_4BYTES); - mlog_catenate_ulint(&mtr, i + 1, MLOG_4BYTES); - mlog_catenate_string(&mtr, buf, 50); - } - mtr_commit(&mtr); - } - tm = ut_clock(); - printf("Wall clock time for %lu log writes %lu milliseconds\n", - i * j, tm - oldtm); - mtr_start(&mtr); - for (j = 0; j < 250; j++) { - mlog_catenate_ulint(&mtr, 5, MLOG_1BYTE); - mlog_catenate_ulint(&mtr, i, MLOG_4BYTES); - mlog_catenate_ulint(&mtr, i + 1, MLOG_4BYTES); - mlog_catenate_string(&mtr, buf, 50); - } - - mtr_print(&mtr); - mtr_commit(&mtr); -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - oldtm = ut_clock(); - - sync_init(); - mem_init(); - log_init(); - - test1(); - test2(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/os/os0fileold.c b/innobase/os/os0fileold.c deleted file mode 100644 index a9554727f0e..00000000000 --- a/innobase/os/os0fileold.c +++ /dev/null @@ -1,1956 +0,0 @@ -/****************************************************** -The interface to the operating system file i/o primitives - -(c) 1995 Innobase Oy - -Created 10/21/1995 Heikki Tuuri -*******************************************************/ - -#include "os0file.h" -#include "os0sync.h" -#include "ut0mem.h" - -#ifndef __WIN__ -#include <errno.h> -#endif - -/* We use these mutexes to protect lseek + file i/o operation, if the -OS does not provide an atomic pread or pwrite, or similar */ -#define OS_FILE_N_SEEK_MUTEXES 16 -os_mutex_t os_file_seek_mutexes[OS_FILE_N_SEEK_MUTEXES]; - -/* In simulated aio, merge at most this many consecutive i/os */ -#define OS_AIO_MERGE_N_CONSECUTIVE 32 - -/* If this flag is TRUE, then we will use the native aio of the -OS (provided we compiled Innobase with it in), otherwise we will -use simulated aio we build below with threads */ - -bool os_aio_use_native_aio = FALSE; - -/* The aio array slot structure */ -typedef struct os_aio_slot_struct os_aio_slot_t; - -struct os_aio_slot_struct{ - bool is_read; /* TRUE if a read operation */ - ulint pos; /* index of the slot in the aio - array */ - bool reserved; /* TRUE if this slot is reserved */ - ulint len; /* length of the block to read or - write */ - byte* buf; /* buffer used in i/o */ - ulint type; /* OS_FILE_READ or OS_FILE_WRITE */ - ulint offset; /* 32 low bits of file offset in - bytes */ - ulint offset_high; /* 32 high bits of file offset */ - os_file_t file; /* file where to read or write */ - char* name; /* file name or path */ - bool io_already_done;/* used only in simulated aio: - TRUE if the physical i/o already - made and only the slot message - needs to be passed to the caller - of os_aio_simulated_handle */ - void* message1; /* message which is given by the */ - void* message2; /* the requester of an aio operation - and which can be used to identify - which pending aio operation was - completed */ -#ifdef WIN_ASYNC_IO - OVERLAPPED control; /* Windows control block for the - aio request */ -#elif defined(POSIX_ASYNC_IO) - struct aiocb control; /* Posix control block for aio - request */ -#endif -}; - -/* The aio array structure */ -typedef struct os_aio_array_struct os_aio_array_t; - -struct os_aio_array_struct{ - os_mutex_t mutex; /* the mutex protecting the aio array */ - os_event_t not_full; /* The event which is set to signaled - state when there is space in the aio - outside the ibuf segment */ - ulint n_slots; /* Total number of slots in the aio array. - This must be divisible by n_threads. */ - ulint n_segments;/* Number of segments in the aio array of - pending aio requests. A thread can wait - separately for any one of the segments. */ - ulint n_reserved;/* Number of reserved slots in the - aio array outside the ibuf segment */ - os_aio_slot_t* slots; /* Pointer to the slots in the array */ - os_event_t* events; /* Pointer to an array of event handles - where we copied the handles from slots, - in the same order. This can be used in - WaitForMultipleObjects; used only in - Windows */ -}; - -/* Array of events used in simulated aio */ -os_event_t* os_aio_segment_wait_events = NULL; - -/* The aio arrays for non-ibuf i/o and ibuf i/o, as well as sync aio. These -are NULL when the module has not yet been initialized. */ -os_aio_array_t* os_aio_read_array = NULL; -os_aio_array_t* os_aio_write_array = NULL; -os_aio_array_t* os_aio_ibuf_array = NULL; -os_aio_array_t* os_aio_log_array = NULL; -os_aio_array_t* os_aio_sync_array = NULL; - -ulint os_aio_n_segments = ULINT_UNDEFINED; - -/*************************************************************************** -Retrieves the last error number if an error occurs in a file io function. -The number should be retrieved before any other OS calls (because they may -overwrite the error number). If the number is not known to this program, -the OS error number + 100 is returned. */ - -ulint -os_file_get_last_error(void) -/*========================*/ - /* out: error number, or OS error number + 100 */ -{ - ulint err; - -#ifdef __WIN__ - - err = (ulint) GetLastError(); - - if (err == ERROR_FILE_NOT_FOUND) { - return(OS_FILE_NOT_FOUND); - } else if (err == ERROR_DISK_FULL) { - return(OS_FILE_DISK_FULL); - } else if (err == ERROR_FILE_EXISTS) { - return(OS_FILE_ALREADY_EXISTS); - } else { - return(100 + err); - } -#else - err = (ulint) errno; - - printf("%lu\n", err); - perror("os0file:"); - - if (err == ENOSPC ) { - return(OS_FILE_DISK_FULL); -#ifdef POSIX_ASYNC_IO - } else if (err == EAGAIN) { - return(OS_FILE_AIO_RESOURCES_RESERVED); -#endif - } else if (err == ENOENT) { - return(OS_FILE_NOT_FOUND); - } else if (err == EEXIST) { - return(OS_FILE_ALREADY_EXISTS); - } else { - return(100 + err); - } -#endif -} - -/******************************************************************** -Does error handling when a file operation fails. If we have run out -of disk space, then the user can clean the disk. If we do not find -a specified file, then the user can copy it to disk. */ -static -bool -os_file_handle_error( -/*=================*/ - /* out: TRUE if we should retry the operation */ - os_file_t file, /* in: file pointer */ - char* name) /* in: name of a file or NULL */ -{ - int input_char; - ulint err; - - err = os_file_get_last_error(); - - if (err == OS_FILE_DISK_FULL) { -ask_again: - printf("\n"); - if (name) { - printf( - "Innobase encountered a problem with file %s.\n", - name); - } - printf("Disk is full. Try to clean the disk to free space\n"); - printf("before answering the following: How to continue?\n"); - printf("(Y == freed some space: try again)\n"); - printf("(N == crash the database: will restart it)?\n"); -ask_with_no_question: - input_char = getchar(); - - if (input_char == (int) 'N') { - ut_error; - - return(FALSE); - } else if (input_char == (int) 'Y') { - - return(TRUE); - } else if (input_char == (int) '\n') { - - goto ask_with_no_question; - } else { - goto ask_again; - } - } else if (err == OS_FILE_AIO_RESOURCES_RESERVED) { - - return(TRUE); - } else { - ut_error; - } - - return(FALSE); -} - -/******************************************************************** -Opens an existing file or creates a new. */ - -os_file_t -os_file_create( -/*===========*/ - /* out, own: handle to the file, not defined if error, - error number can be retrieved with os_get_last_error */ - char* name, /* in: name of the file or path as a null-terminated - string */ - ulint create_mode, /* in: OS_FILE_OPEN if an existing file is opened - (if does not exist, error), or OS_FILE_CREATE if a new - file is created (if exists, error), OS_FILE_OVERWRITE - if a new is created or an old overwritten */ - ulint purpose,/* in: OS_FILE_AIO, if asynchronous, non-buffered i/o - is desired, OS_FILE_NORMAL, if any normal file */ - bool* success)/* out: TRUE if succeed, FALSE if error */ -{ -#ifdef __WIN__ - os_file_t file; - DWORD create_flag; - DWORD attributes; - bool retry; - -try_again: - ut_a(name); - - if (create_mode == OS_FILE_OPEN) { - create_flag = OPEN_EXISTING; - } else if (create_mode == OS_FILE_CREATE) { - create_flag = CREATE_NEW; - } else if (create_mode == OS_FILE_OVERWRITE) { - create_flag = CREATE_ALWAYS; - } else { - create_flag = 0; - ut_error; - } - - if (purpose == OS_FILE_AIO) { - /* use asynchronous (overlapped) io and no buffering - of writes in the OS */ - attributes = 0; -#ifdef WIN_ASYNC_IO - if (os_aio_use_native_aio) { - attributes = attributes | FILE_FLAG_OVERLAPPED; - } -#endif -#ifdef UNIV_NON_BUFFERED_IO - attributes = attributes | FILE_FLAG_NO_BUFFERING; -#endif - } else if (purpose == OS_FILE_NORMAL) { - attributes = 0 -#ifdef UNIV_NON_BUFFERED_IO - | FILE_FLAG_NO_BUFFERING -#endif - ; - } else { - attributes = 0; - ut_error; - } - - file = CreateFile(name, - GENERIC_READ | GENERIC_WRITE, /* read and write - access */ - FILE_SHARE_READ,/* file can be read by other - processes */ - NULL, /* default security attributes */ - create_flag, - attributes, - NULL); /* no template file */ - - if (file == INVALID_HANDLE_VALUE) { - *success = FALSE; - - if (create_mode != OS_FILE_OPEN - && os_file_get_last_error() == OS_FILE_DISK_FULL) { - - retry = os_file_handle_error(file, name); - - if (retry) { - goto try_again; - } - } - } else { - *success = TRUE; - } - - return(file); -#else - os_file_t file; - int create_flag; - bool retry; - -try_again: - ut_a(name); - - if (create_mode == OS_FILE_OPEN) { - create_flag = O_RDWR; - } else if (create_mode == OS_FILE_CREATE) { - create_flag = O_RDWR | O_CREAT | O_EXCL; - } else if (create_mode == OS_FILE_OVERWRITE) { - create_flag = O_RDWR | O_CREAT | O_TRUNC; - } else { - create_flag = 0; - ut_error; - } - - UT_NOT_USED(purpose); - - if (create_mode == OS_FILE_CREATE) { - - file = open(name, create_flag, S_IRWXU | S_IRWXG | S_IRWXO); - } else { - file = open(name, create_flag); - } - - if (file == -1) { - *success = FALSE; - - printf("Error in opening file %s, errno %lu\n", name, - (ulint)errno); - perror("os0file.c:"); - - if (create_mode != OS_FILE_OPEN - && errno == ENOSPC) { - - retry = os_file_handle_error(file, name); - - if (retry) { - goto try_again; - } - } - } else { - *success = TRUE; - } - - return(file); -#endif -} - -/*************************************************************************** -Closes a file handle. In case of error, error number can be retrieved with -os_file_get_last_error. */ - -bool -os_file_close( -/*==========*/ - /* out: TRUE if success */ - os_file_t file) /* in, own: handle to a file */ -{ -#ifdef __WIN__ - BOOL ret; - - ut_a(file); - - ret = CloseHandle(file); - - if (ret) { - return(TRUE); - } - - return(FALSE); -#else - int ret; - - ret = close(file); - - if (ret == -1) { - return(FALSE); - } - - return(TRUE); -#endif -} - -/*************************************************************************** -Gets a file size. */ - -bool -os_file_get_size( -/*=============*/ - /* out: TRUE if success */ - os_file_t file, /* in: handle to a file */ - ulint* size, /* out: least significant 32 bits of file - size */ - ulint* size_high)/* out: most significant 32 bits of size */ -{ -#ifdef __WIN__ - DWORD high; - DWORD low; - - low = GetFileSize(file, &high); - - if ((low == 0xFFFFFFFF) && (GetLastError() != NO_ERROR)) { - return(FALSE); - } - - *size = low; - *size_high = high; - - return(TRUE); -#else - *size = (ulint) lseek(file, 0, SEEK_END); - *size_high = 0; - - return(TRUE); -#endif -} - -/*************************************************************************** -Sets a file size. This function can be used to extend or truncate a file. */ - -bool -os_file_set_size( -/*=============*/ - /* out: TRUE if success */ - char* name, /* in: name of the file or path as a - null-terminated string */ - os_file_t file, /* in: handle to a file */ - ulint size, /* in: least significant 32 bits of file - size */ - ulint size_high)/* in: most significant 32 bits of size */ -{ -#ifdef __WIN__ - DWORD high; - DWORD low; - DWORD ret; - BOOL ret2; - DWORD err; - bool retry; - -try_again: - low = size; - high = size_high; - - ret = SetFilePointer(file, low, &high, FILE_BEGIN); - - if (ret == 0xFFFFFFFF && GetLastError() != NO_ERROR) { - err = GetLastError(); - - goto error_handling; - } - - ret2 = SetEndOfFile(file); - - if (ret2) { - ret2 = os_file_flush(file); - } - - if (ret2) { - return(TRUE); - } -#else - ulint offset; - ulint n_bytes; - ulint low; - ssize_t ret; - bool retry; - ulint i; - byte buf[UNIV_PAGE_SIZE * 8]; - - /* Write buffer full of zeros */ - for (i = 0; i < UNIV_PAGE_SIZE * 8; i++) { - buf[i] = '\0'; - } - -try_again: - low = size; -#if (UNIV_WORD_SIZE == 8) - low = low + (size_high << 32); -#endif - while (offset < low) { - if (low - offset < UNIV_PAGE_SIZE * 8) { - n_bytes = low - offset; - } else { - n_bytes = UNIV_PAGE_SIZE * 8; - } - - ret = pwrite(file, buf, n_bytes, offset); - - if (ret != n_bytes) { - goto error_handling; - } - offset += n_bytes; - } - - ret = os_file_flush(file); - - if (ret) { - return(TRUE); - } -#endif - -error_handling: - retry = os_file_handle_error(file, name); - - if (retry) { - goto try_again; - } - - ut_error; -} - -/*************************************************************************** -Flushes the write buffers of a given file to the disk. */ - -bool -os_file_flush( -/*==========*/ - /* out: TRUE if success */ - os_file_t file) /* in, own: handle to a file */ -{ -#ifdef __WIN__ - BOOL ret; - - ut_a(file); - - ret = FlushFileBuffers(file); - - if (ret) { - return(TRUE); - } - - return(FALSE); -#else - int ret; - - ret = fsync(file); - - if (ret == 0) { - return(TRUE); - } - - return(FALSE); -#endif -} - - -#ifndef __WIN__ -/*********************************************************************** -Does a synchronous read operation in Posix. */ -static -ssize_t -os_file_pread( -/*==========*/ - /* out: number of bytes read, -1 if error */ - os_file_t file, /* in: handle to a file */ - void* buf, /* in: buffer where to read */ - ulint n, /* in: number of bytes to read */ - ulint offset) /* in: offset from where to read */ -{ -#ifdef HAVE_PREAD - return(pread(file, buf, n, (off_t) offset)); -#else - ssize_t ret; - ulint i; - - /* Protect the seek / read operation with a mutex */ - i = ((ulint) file) % OS_FILE_N_SEEK_MUTEXES; - - os_mutex_enter(os_file_seek_mutexes[i]); - - ret = lseek(file, (off_t) offset, 0); - - if (ret < 0) { - os_mutex_exit(os_file_seek_mutexes[i]); - - return(ret); - } - - ret = read(file, buf, n); - - os_mutex_exit(os_file_seek_mutexes[i]); - - return(ret); -#endif -} - -/*********************************************************************** -Does a synchronous write operation in Posix. */ -static -ssize_t -os_file_pwrite( -/*===========*/ - /* out: number of bytes written, -1 if error */ - os_file_t file, /* in: handle to a file */ - void* buf, /* in: buffer from where to write */ - ulint n, /* in: number of bytes to write */ - ulint offset) /* in: offset where to write */ -{ -#ifdef HAVE_PWRITE - return(pwrite(file, buf, n, (off_t) offset)); -#else - ssize_t ret; - ulint i; - - /* Protect the seek / write operation with a mutex */ - i = ((ulint) file) % OS_FILE_N_SEEK_MUTEXES; - - os_mutex_enter(os_file_seek_mutexes[i]); - - ret = lseek(file, (off_t) offset, 0); - - if (ret < 0) { - os_mutex_exit(os_file_seek_mutexes[i]); - - return(ret); - } - - ret = write(file, buf, n); - - os_mutex_exit(os_file_seek_mutexes[i]); - - return(ret); -#endif -} -#endif - -/*********************************************************************** -Requests a synchronous positioned read operation. */ - -bool -os_file_read( -/*=========*/ - /* out: TRUE if request was - successful, FALSE if fail */ - os_file_t file, /* in: handle to a file */ - void* buf, /* in: buffer where to read */ - ulint offset, /* in: least significant 32 bits of file - offset where to read */ - ulint offset_high, /* in: most significant 32 bits of - offset */ - ulint n) /* in: number of bytes to read */ -{ -#ifdef __WIN__ - BOOL ret; - DWORD len; - DWORD ret2; - DWORD err; - DWORD low; - DWORD high; - bool retry; - ulint i; - -try_again: - ut_ad(file); - ut_ad(buf); - ut_ad(n > 0); - - low = offset; - high = offset_high; - - /* Protect the seek / read operation with a mutex */ - i = ((ulint) file) % OS_FILE_N_SEEK_MUTEXES; - - os_mutex_enter(os_file_seek_mutexes[i]); - - ret2 = SetFilePointer(file, low, &high, FILE_BEGIN); - - if (ret2 == 0xFFFFFFFF && GetLastError() != NO_ERROR) { - err = GetLastError(); - - os_mutex_exit(os_file_seek_mutexes[i]); - - goto error_handling; - } - - ret = ReadFile(file, buf, n, &len, NULL); - - os_mutex_exit(os_file_seek_mutexes[i]); - - if (ret && len == n) { - return(TRUE); - } - - err = GetLastError(); -#else - bool retry; - ssize_t ret; - ulint i; - -#if (UNIV_WORD_SIZE == 8) - offset = offset + (offset_high << 32); -#endif -try_again: - /* Protect the seek / read operation with a mutex */ - i = ((ulint) file) % OS_FILE_N_SEEK_MUTEXES; - - os_mutex_enter(os_file_seek_mutexes[i]); - - ret = os_file_pread(file, buf, n, (off_t) offset); - - if (ret == n) { - os_mutex_exit(os_file_seek_mutexes[i]); - - return(TRUE); - } -#endif -error_handling: - retry = os_file_handle_error(file, NULL); - - if (retry) { - goto try_again; - } - - ut_error; - - return(FALSE); -} - -/*********************************************************************** -Requests a synchronous write operation. */ - -bool -os_file_write( -/*==========*/ - /* out: TRUE if request was - successful, FALSE if fail */ - char* name, /* in: name of the file or path as a - null-terminated string */ - os_file_t file, /* in: handle to a file */ - void* buf, /* in: buffer from which to write */ - ulint offset, /* in: least significant 32 bits of file - offset where to write */ - ulint offset_high, /* in: most significant 32 bits of - offset */ - ulint n) /* in: number of bytes to write */ -{ -#ifdef __WIN__ - BOOL ret; - DWORD len; - DWORD ret2; - DWORD err; - DWORD low; - DWORD high; - bool retry; - ulint i; - -try_again: - ut_ad(file); - ut_ad(buf); - ut_ad(n > 0); - - low = offset; - high = offset_high; - - /* Protect the seek / write operation with a mutex */ - i = ((ulint) file) % OS_FILE_N_SEEK_MUTEXES; - - os_mutex_enter(os_file_seek_mutexes[i]); - - ret2 = SetFilePointer(file, low, &high, FILE_BEGIN); - - if (ret2 == 0xFFFFFFFF && GetLastError() != NO_ERROR) { - err = GetLastError(); - - os_mutex_exit(os_file_seek_mutexes[i]); - - goto error_handling; - } - - ret = WriteFile(file, buf, n, &len, NULL); - - os_mutex_exit(os_file_seek_mutexes[i]); - - if (ret && len == n) { - return(TRUE); - } -#else - bool retry; - ssize_t ret; - -#if (UNIV_WORD_SIZE == 8) - offset = offset + (offset_high << 32); -#endif -try_again: - ret = pwrite(file, buf, n, (off_t) offset); - - if (ret == n) { - return(TRUE); - } -#endif - -error_handling: - retry = os_file_handle_error(file, name); - - if (retry) { - goto try_again; - } - - ut_error; - - return(FALSE); -} - -/******************************************************************** -Returns a pointer to the nth slot in the aio array. */ -static -os_aio_slot_t* -os_aio_array_get_nth_slot( -/*======================*/ - /* out: pointer to slot */ - os_aio_array_t* array, /* in: aio array */ - ulint index) /* in: index of the slot */ -{ - ut_a(index < array->n_slots); - - return((array->slots) + index); -} - -/**************************************************************************** -Creates an aio wait array. */ -static -os_aio_array_t* -os_aio_array_create( -/*================*/ - /* out, own: aio array */ - ulint n, /* in: maximum number of pending aio operations - allowed; n must be divisible by n_segments */ - ulint n_segments) /* in: number of segments in the aio array */ -{ - os_aio_array_t* array; - ulint i; - os_aio_slot_t* slot; -#ifdef WIN_ASYNC_IO - OVERLAPPED* over; -#endif - ut_a(n > 0); - ut_a(n_segments > 0); - ut_a(n % n_segments == 0); - - array = ut_malloc(sizeof(os_aio_array_t)); - - array->mutex = os_mutex_create(NULL); - array->not_full = os_event_create(NULL); - array->n_slots = n; - array->n_segments = n_segments; - array->n_reserved = 0; - array->slots = ut_malloc(n * sizeof(os_aio_slot_t)); - array->events = ut_malloc(n * sizeof(os_event_t)); - - for (i = 0; i < n; i++) { - slot = os_aio_array_get_nth_slot(array, i); - - slot->pos = i; - slot->reserved = FALSE; -#ifdef WIN_ASYNC_IO - over = &(slot->control); - - over->hEvent = os_event_create(NULL); - - *((array->events) + i) = over->hEvent; -#elif defined(POSIX_ASYNC_IO) - slot->ready = os_event_create(NULL); -#endif - } - - return(array); -} - -/**************************************************************************** -Initializes the asynchronous io system. Creates separate aio array for -non-ibuf read and write, a third aio array for the ibuf i/o, with just one -segment, two aio arrays for log reads and writes with one segment, and a -synchronous aio array of the specified size. The combined number of segments -in the three first aio arrays is the parameter n_segments given to the -function. The caller must create an i/o handler thread for each segment in -the four first arrays, but not for the sync aio array. */ - -void -os_aio_init( -/*========*/ - ulint n, /* in: maximum number of pending aio operations - allowed; n must be divisible by n_segments */ - ulint n_segments, /* in: combined number of segments in the four - first aio arrays; must be >= 4 */ - ulint n_slots_sync) /* in: number of slots in the sync aio array */ -{ - ulint n_read_segs; - ulint n_write_segs; - ulint n_per_seg; - ulint i; - - ut_ad(n % n_segments == 0); - ut_ad(n_segments >= 4); - - n_per_seg = n / n_segments; - n_write_segs = (n_segments - 2) / 2; - n_read_segs = n_segments - 2 - n_write_segs; - - os_aio_read_array = os_aio_array_create(n_read_segs * n_per_seg, - n_read_segs); - os_aio_write_array = os_aio_array_create(n_write_segs * n_per_seg, - n_write_segs); - os_aio_ibuf_array = os_aio_array_create(n_per_seg, 1); - - os_aio_log_array = os_aio_array_create(n_per_seg, 1); - - os_aio_sync_array = os_aio_array_create(n_slots_sync, 1); - - os_aio_n_segments = n_segments; - -#if !(defined(WIN_ASYNC_IO) || defined(POSIX_ASYNC_IO)) - os_aio_use_native_aio = FALSE; -#endif - os_aio_validate(); - - for (i = 0; i < OS_FILE_N_SEEK_MUTEXES; i++) { - os_file_seek_mutexes[i] = os_mutex_create(NULL); - } - - os_aio_segment_wait_events = ut_malloc(n_segments * sizeof(void*)); - - for (i = 0; i < n_segments; i++) { - os_aio_segment_wait_events[i] = os_event_create(NULL); - } -} - -/************************************************************************** -Calculates segment number for a slot. */ -static -ulint -os_aio_get_segment_no_from_slot( -/*============================*/ - /* out: segment number (which is the number - used by, for example, i/o-handler threads) */ - os_aio_array_t* array, /* in: aio wait array */ - os_aio_slot_t* slot) /* in: slot in this array */ -{ - ulint segment; - ulint seg_len; - - if (array == os_aio_ibuf_array) { - segment = 0; - - } else if (array == os_aio_log_array) { - segment = 1; - - } else if (array == os_aio_read_array) { - seg_len = os_aio_read_array->n_slots / - os_aio_read_array->n_segments; - - segment = 2 + slot->pos / seg_len; - } else { - ut_a(array == os_aio_write_array); - seg_len = os_aio_write_array->n_slots / - os_aio_write_array->n_segments; - - segment = os_aio_read_array->n_segments + 2 - + slot->pos / seg_len; - } - - return(segment); -} - -/************************************************************************** -Calculates local segment number and aio array from global segment number. */ -static -ulint -os_aio_get_array_and_local_segment( -/*===============================*/ - /* out: local segment number within - the aio array */ - os_aio_array_t** array, /* out: aio wait array */ - ulint global_segment)/* in: global segment number */ -{ - ulint segment; - - ut_a(global_segment < os_aio_n_segments); - - if (global_segment == 0) { - *array = os_aio_ibuf_array; - segment = 0; - - } else if (global_segment == 1) { - *array = os_aio_log_array; - segment = 0; - - } else if (global_segment < os_aio_read_array->n_segments + 2) { - *array = os_aio_read_array; - - segment = global_segment - 2; - } else { - *array = os_aio_write_array; - - segment = global_segment - (os_aio_read_array->n_segments + 2); - } - - return(segment); -} - -/*********************************************************************** -Gets an integer value designating a specified aio array. This is used -to give numbers to signals in Posix aio. */ -static -ulint -os_aio_get_array_no( -/*================*/ - os_aio_array_t* array) /* in: aio array */ -{ - if (array == os_aio_ibuf_array) { - - return(0); - - } else if (array == os_aio_log_array) { - - return(1); - - } else if (array == os_aio_read_array) { - - return(2); - } else if (array == os_aio_write_array) { - - return(3); - } else { - ut_a(0); - - return(0); - } -} - -/*********************************************************************** -Gets the aio array for its number. */ -static -os_aio_array_t* -os_aio_get_array_from_no( -/*=====================*/ - /* out: aio array */ - ulint n) /* in: array number */ -{ - if (n == 0) { - return(os_aio_ibuf_array); - } else if (n == 1) { - - return(os_aio_log_array); - } else if (n == 2) { - - return(os_aio_read_array); - } else if (n == 3) { - - return(os_aio_write_array); - } else { - ut_a(0); - - return(NULL); - } -} - -/*********************************************************************** -Requests for a slot in the aio array. If no slot is available, waits until -not_full-event becomes signaled. */ -static -os_aio_slot_t* -os_aio_array_reserve_slot( -/*======================*/ - /* out: pointer to slot */ - ulint type, /* in: OS_FILE_READ or OS_FILE_WRITE */ - os_aio_array_t* array, /* in: aio array */ - void* message1,/* in: message to be passed along with - the aio operation */ - void* message2,/* in: message to be passed along with - the aio operation */ - os_file_t file, /* in: file handle */ - char* name, /* in: name of the file or path as a - null-terminated string */ - void* buf, /* in: buffer where to read or from which - to write */ - ulint offset, /* in: least significant 32 bits of file - offset */ - ulint offset_high, /* in: most significant 32 bits of - offset */ - ulint len) /* in: length of the block to read or write */ -{ - os_aio_slot_t* slot; -#ifdef WIN_ASYNC_IO - OVERLAPPED* control; -#elif POSIX_ASYNC_IO - struct aiocb* control; - ulint type; -#endif - ulint i; -loop: - os_mutex_enter(array->mutex); - - if (array->n_reserved == array->n_slots) { - os_mutex_exit(array->mutex); - os_event_wait(array->not_full); - - goto loop; - } - - for (i = 0;; i++) { - slot = os_aio_array_get_nth_slot(array, i); - - if (slot->reserved == FALSE) { - break; - } - } - - array->n_reserved++; - - if (array->n_reserved == array->n_slots) { - os_event_reset(array->not_full); - } - - slot->reserved = TRUE; - slot->message1 = message1; - slot->message2 = message2; - slot->file = file; - slot->name = name; - slot->len = len; - slot->type = type; - slot->buf = buf; - slot->offset = offset; - slot->offset_high = offset_high; - slot->io_already_done = FALSE; - -#ifdef WIN_ASYNC_IO - control = &(slot->control); - control->Offset = (DWORD)offset; - control->OffsetHigh = (DWORD)offset_high; - os_event_reset(control->hEvent); - -#elif POSIX_ASYNC_IO - -#if (UNIV_WORD_SIZE == 8) - offset = offset + (offset_high << 32); -#else - ut_a(offset_high == 0); -#endif - control = &(slot->control); - control->aio_fildes = file; - control->aio_buf = buf; - control->aio_nbytes = len; - control->aio_offset = offset; - control->aio_reqprio = 0; - control->aio_sigevent.sigev_notify = SIGEV_SIGNAL; - control->aio_sigevent.signo = - SIGRTMAX + 1 + os_aio_get_array_no(array); - /* TODO: How to choose the signal numbers? */ - control->aio_sigevent.sigev_value.sival_ptr = slot; -#endif - os_mutex_exit(array->mutex); - - return(slot); -} - -/*********************************************************************** -Frees a slot in the aio array. */ -static -void -os_aio_array_free_slot( -/*===================*/ - os_aio_array_t* array, /* in: aio array */ - os_aio_slot_t* slot) /* in: pointer to slot */ -{ - ut_ad(array); - ut_ad(slot); - - os_mutex_enter(array->mutex); - - ut_ad(slot->reserved); - - slot->reserved = FALSE; - - array->n_reserved--; - - if (array->n_reserved == array->n_slots - 1) { - os_event_set(array->not_full); - } - -#ifdef WIN_ASYNC_IO - os_event_reset(slot->control.hEvent); -#endif - os_mutex_exit(array->mutex); -} - -/************************************************************************** -Wakes up a simulated aio i/o-handler thread if it has something to do. */ -static -void -os_aio_simulated_wake_handler_thread( -/*=================================*/ - ulint global_segment) /* in: the number of the segment in the aio - arrays */ -{ - os_aio_array_t* array; - ulint segment; - os_aio_slot_t* slot; - ulint n; - ulint i; - - ut_ad(!os_aio_use_native_aio); - - segment = os_aio_get_array_and_local_segment(&array, global_segment); - - n = array->n_slots / array->n_segments; - - /* Look through n slots after the segment * n'th slot */ - - os_mutex_enter(array->mutex); - - for (i = 0; i < n; i++) { - slot = os_aio_array_get_nth_slot(array, i + segment * n); - - if (slot->reserved) { - /* Found an i/o request */ - - break; - } - } - - os_mutex_exit(array->mutex); - - if (i < n) { - os_event_set(os_aio_segment_wait_events[global_segment]); - } -} - -/************************************************************************** -Wakes up simulated aio i/o-handler threads if they have something to do. */ - -void -os_aio_simulated_wake_handler_threads(void) -/*=======================================*/ -{ - ulint i; - - if (os_aio_use_native_aio) { - /* We do not use simulated aio: do nothing */ - - return; - } - - for (i = 0; i < os_aio_n_segments; i++) { - os_aio_simulated_wake_handler_thread(i); - } -} - -/*********************************************************************** -Requests an asynchronous i/o operation. */ - -bool -os_aio( -/*===*/ - /* out: TRUE if request was queued - successfully, FALSE if fail */ - ulint type, /* in: OS_FILE_READ or OS_FILE_WRITE */ - ulint mode, /* in: OS_AIO_NORMAL, ..., possibly ORed - to OS_AIO_SIMULATED_WAKE_LATER: the - last flag advises this function not to wake - i/o-handler threads, but the caller will - do the waking explicitly later, in this - way the caller can post several requests in - a batch; NOTE that the batch must not be - so big that it exhausts the slots in aio - arrays! NOTE that a simulated batch - may introduce hidden chances of deadlocks, - because i/os are not actually handled until - all have been posted: use with great - caution! */ - char* name, /* in: name of the file or path as a - null-terminated string */ - os_file_t file, /* in: handle to a file */ - void* buf, /* in: buffer where to read or from which - to write */ - ulint offset, /* in: least significant 32 bits of file - offset where to read or write */ - ulint offset_high, /* in: most significant 32 bits of - offset */ - ulint n, /* in: number of bytes to read or write */ - void* message1,/* in: messages for the aio handler (these - can be used to identify a completed aio - operation); if mode is OS_AIO_SYNC, these - are ignored */ - void* message2) -{ - os_aio_array_t* array; - os_aio_slot_t* slot; -#ifdef WIN_ASYNC_IO - BOOL ret = TRUE; - DWORD len = n; - void* dummy_mess1; - void* dummy_mess2; -#endif - ulint err = 0; - bool retry; - ulint wake_later; - - ut_ad(file); - ut_ad(buf); - ut_ad(n > 0); - ut_ad(n % OS_FILE_LOG_BLOCK_SIZE == 0); - ut_ad((ulint)buf % OS_FILE_LOG_BLOCK_SIZE == 0) - ut_ad(offset % OS_FILE_LOG_BLOCK_SIZE == 0); - ut_ad(os_aio_validate()); - - wake_later = mode & OS_AIO_SIMULATED_WAKE_LATER; - mode = mode & (~OS_AIO_SIMULATED_WAKE_LATER); - - if (mode == OS_AIO_SYNC -#ifdef WIN_ASYNC_IO - && !os_aio_use_native_aio -#endif - ) { - /* This is actually an ordinary synchronous read or write: - no need to use an i/o-handler thread. NOTE that if we use - Windows async i/o, Windows does not allow us to use - ordinary synchronous os_file_read etc. on the same file, - therefore we have built a special mechanism for synchronous - wait in the Windows case. */ - - if (type == OS_FILE_READ) { - return(os_file_read(file, buf, offset, offset_high, n)); - } - - ut_a(type == OS_FILE_WRITE); - - return(os_file_write(name, file, buf, offset, offset_high, n)); - } - -try_again: - if (mode == OS_AIO_NORMAL) { - if (type == OS_FILE_READ) { - array = os_aio_read_array; - } else { - array = os_aio_write_array; - } - } else if (mode == OS_AIO_IBUF) { - ut_ad(type == OS_FILE_READ); - - array = os_aio_ibuf_array; - } else if (mode == OS_AIO_LOG) { - - array = os_aio_log_array; - } else if (mode == OS_AIO_SYNC) { - array = os_aio_sync_array; - } else { - ut_error; - } - - slot = os_aio_array_reserve_slot(type, array, message1, message2, file, - name, buf, offset, offset_high, n); - if (type == OS_FILE_READ) { - if (os_aio_use_native_aio) { -#ifdef WIN_ASYNC_IO - ret = ReadFile(file, buf, (DWORD)n, &len, - &(slot->control)); -#elif defined(POSIX_ASYNC_IO) - err = (ulint) aio_read(&(slot->control)); -#endif - } else { - if (!wake_later) { - os_aio_simulated_wake_handler_thread( - os_aio_get_segment_no_from_slot(array, slot)); - } - } - } else if (type == OS_FILE_WRITE) { - if (os_aio_use_native_aio) { -#ifdef WIN_ASYNC_IO - ret = WriteFile(file, buf, (DWORD)n, &len, - &(slot->control)); -#elif defined(POSIX_ASYNC_IO) - err = (ulint) aio_write(&(slot->control)); -#endif - } else { - if (!wake_later) { - os_aio_simulated_wake_handler_thread( - os_aio_get_segment_no_from_slot(array, slot)); - } - } - } else { - ut_error; - } - -#ifdef WIN_ASYNC_IO - if ((ret && len == n) - || (!ret && GetLastError() == ERROR_IO_PENDING)) { - - /* aio was queued successfully! */ - - if (mode == OS_AIO_SYNC) { - /* We want a synchronous i/o operation on a file - where we also use async i/o: in Windows we must - use the same wait mechanism as for async i/o */ - - return(os_aio_windows_handle(ULINT_UNDEFINED, - slot->pos, - &dummy_mess1, &dummy_mess2)); - } - - return(TRUE); - } -#else - if (err == 0) { - /* aio was queued successfully! */ - - return(TRUE); - } -#endif - os_aio_array_free_slot(array, slot); - - retry = os_file_handle_error(file, name); - - if (retry) { - - goto try_again; - } - - ut_error; - - return(FALSE); -} - -#ifdef WIN_ASYNC_IO -/************************************************************************** -This function is only used in Windows asynchronous i/o. -Waits for an aio operation to complete. This function is used to wait the -for completed requests. The aio array of pending requests is divided -into segments. The thread specifies which segment or slot it wants to wait -for. NOTE: this function will also take care of freeing the aio slot, -therefore no other thread is allowed to do the freeing! */ - -bool -os_aio_windows_handle( -/*==================*/ - /* out: TRUE if the aio operation succeeded */ - ulint segment, /* in: the number of the segment in the aio - arrays to wait for; segment 0 is the ibuf - i/o thread, segment 1 the log i/o thread, - then follow the non-ibuf read threads, and as - the last are the non-ibuf write threads; if - this is ULINT_UNDEFINED, then it means that - sync aio is used, and this parameter is - ignored */ - ulint pos, /* this parameter is used only in sync aio: - wait for the aio slot at this position */ - void** message1, /* out: the messages passed with the aio - request; note that also in the case where - the aio operation failed, these output - parameters are valid and can be used to - restart the operation, for example */ - void** message2) -{ - os_aio_array_t* array; - os_aio_slot_t* slot; - ulint n; - ulint i; - bool ret_val; - ulint err; - BOOL ret; - DWORD len; - - if (segment == ULINT_UNDEFINED) { - array = os_aio_sync_array; - segment = 0; - } else { - segment = os_aio_get_array_and_local_segment(&array, segment); - } - - /* NOTE! We only access constant fields in os_aio_array. Therefore - we do not have to acquire the protecting mutex yet */ - - ut_ad(os_aio_validate()); - ut_ad(segment < array->n_segments); - - n = array->n_slots / array->n_segments; - - if (array == os_aio_sync_array) { - ut_ad(pos < array->n_slots); - os_event_wait(array->events[pos]); - i = pos; - } else { - i = os_event_wait_multiple(n, (array->events) + segment * n); - } - - os_mutex_enter(array->mutex); - - slot = os_aio_array_get_nth_slot(array, i + segment * n); - - ut_a(slot->reserved); - - ret = GetOverlappedResult(slot->file, &(slot->control), &len, TRUE); - - *message1 = slot->message1; - *message2 = slot->message2; - - if (ret && len == slot->len) { - ret_val = TRUE; - } else { - err = GetLastError(); - ut_error; - - ret_val = FALSE; - } - - os_mutex_exit(array->mutex); - - os_aio_array_free_slot(array, slot); - - return(ret_val); -} -#endif - -#ifdef POSIX_ASYNC_IO -/************************************************************************** -This function is only used in Posix asynchronous i/o. Waits for an aio -operation to complete. */ - -bool -os_aio_posix_handle( -/*================*/ - /* out: TRUE if the aio operation succeeded */ - ulint array_no, /* in: array number 0 - 3 */ - void** message1, /* out: the messages passed with the aio - request; note that also in the case where - the aio operation failed, these output - parameters are valid and can be used to - restart the operation, for example */ - void** message2) -{ - os_aio_array_t* array; - os_aio_slot_t* slot; - siginfo_t info; - sigset_t sigset; - int ret; - - sigemptyset(&sigset); - sigaddset(&sigset, SIGRTMAX + 1 + array_no); - - ret = sigwaitinfo(&sigset, &info); - - if (ret != SIGRTMAX + 1 + array_no) { - - ut_a(0); - - return(FALSE); - } - - array = os_aio_get_array_from_no(array_no); - - os_mutex_enter(array->mutex); - - slot = siginfo.si_value.sival_ptr; - - ut_a(slot->reserved); - - *message1 = slot->message1; - *message2 = slot->message2; - - os_mutex_exit(array->mutex); - - os_aio_array_free_slot(array, slot); - - return(TRUE); -} -#endif - -/************************************************************************** -Does simulated aio. This function should be called by an i/o-handler -thread. */ - -bool -os_aio_simulated_handle( -/*====================*/ - /* out: TRUE if the aio operation succeeded */ - ulint global_segment, /* in: the number of the segment in the aio - arrays to wait for; segment 0 is the ibuf - i/o thread, segment 1 the log i/o thread, - then follow the non-ibuf read threads, and as - the last are the non-ibuf write threads */ - void** message1, /* out: the messages passed with the aio - request; note that also in the case where - the aio operation failed, these output - parameters are valid and can be used to - restart the operation, for example */ - void** message2) -{ - os_aio_array_t* array; - ulint segment; - os_aio_slot_t* slot; - os_aio_slot_t* slot2; - os_aio_slot_t* consecutive_ios[OS_AIO_MERGE_N_CONSECUTIVE]; - ulint n_consecutive; - ulint total_len; - ulint offs; - byte* combined_buf; - bool ret; - ulint n; - ulint i; - - segment = os_aio_get_array_and_local_segment(&array, global_segment); - -restart: - /* NOTE! We only access constant fields in os_aio_array. Therefore - we do not have to acquire the protecting mutex yet */ - - ut_ad(os_aio_validate()); - ut_ad(segment < array->n_segments); - - n = array->n_slots / array->n_segments; - - /* Look through n slots after the segment * n'th slot */ - - os_mutex_enter(array->mutex); - - /* Check if there is a slot for which the i/o has already been - done */ - - for (i = 0; i < n; i++) { - slot = os_aio_array_get_nth_slot(array, i + segment * n); - - if (slot->reserved && slot->io_already_done) { - - goto slot_io_done; - } - } - - n_consecutive = 0; - - for (i = 0; i < n; i++) { - slot = os_aio_array_get_nth_slot(array, i + segment * n); - - if (slot->reserved) { - /* Found an i/o request */ - consecutive_ios[n_consecutive] = slot; - n_consecutive++; - - break; - } - } - - /* Check if there are several consecutive blocks to read or write */ - -consecutive_loop: - for (i = 0; i < n; i++) { - slot2 = os_aio_array_get_nth_slot(array, i + segment * n); - - if (slot2->reserved && slot2 != slot - && slot2->offset == slot->offset + slot->len - && slot->offset + slot->len > slot->offset /* check that - sum does not wrap over */ - && slot2->offset_high == slot->offset_high - && slot2->type == slot->type - && slot2->file == slot->file) { - - /* Found a consecutive i/o request */ - - consecutive_ios[n_consecutive] = slot2; - n_consecutive++; - - slot = slot2; - - if (n_consecutive < OS_AIO_MERGE_N_CONSECUTIVE) { - - goto consecutive_loop; - } else { - break; - } - } - } - - if (n_consecutive == 0) { - - /* No i/o requested at the moment */ - - goto wait_for_io; - } - - /* We have now collected n_consecutive i/o requests in the array; - allocate a single buffer which can hold all data, and perform the - i/o */ - - total_len = 0; - slot = consecutive_ios[0]; - - for (i = 0; i < n_consecutive; i++) { - total_len += consecutive_ios[i]->len; - } - - if (n_consecutive == 1) { - /* We can use the buffer of the i/o request */ - combined_buf = slot->buf; - } else { - combined_buf = ut_malloc(total_len); - - ut_a(combined_buf); - } - - /* We release the array mutex for the time of the i/o: NOTE that - this assumes that there is just one i/o-handler thread serving - a single segment of slots! */ - - os_mutex_exit(array->mutex); - - if (slot->type == OS_FILE_WRITE && n_consecutive > 1) { - /* Copy the buffers to the combined buffer */ - offs = 0; - - for (i = 0; i < n_consecutive; i++) { - - ut_memcpy(combined_buf + offs, consecutive_ios[i]->buf, - consecutive_ios[i]->len); - offs += consecutive_ios[i]->len; - } - } - - /* Do the i/o with ordinary, synchronous i/o functions: */ - if (slot->type == OS_FILE_WRITE) { - ret = os_file_write(slot->name, slot->file, combined_buf, - slot->offset, slot->offset_high, total_len); - } else { - ret = os_file_read(slot->file, combined_buf, - slot->offset, slot->offset_high, total_len); - } - - ut_a(ret); - - if (slot->type == OS_FILE_READ && n_consecutive > 1) { - /* Copy the combined buffer to individual buffers */ - offs = 0; - - for (i = 0; i < n_consecutive; i++) { - - ut_memcpy(consecutive_ios[i]->buf, combined_buf + offs, - consecutive_ios[i]->len); - offs += consecutive_ios[i]->len; - } - } - - if (n_consecutive > 1) { - ut_free(combined_buf); - } - - os_mutex_enter(array->mutex); - - /* Mark the i/os done in slots */ - - for (i = 0; i < n_consecutive; i++) { - consecutive_ios[i]->io_already_done = TRUE; - } - - /* We return the messages for the first slot now, and if there were - several slots, the messages will be returned with subsequent calls - of this function */ - -slot_io_done: - - ut_a(slot->reserved); - - *message1 = slot->message1; - *message2 = slot->message2; - - os_mutex_exit(array->mutex); - - os_aio_array_free_slot(array, slot); - - return(ret); - -wait_for_io: - /* We wait here until there again can be i/os in the segment - of this thread */ - - os_event_reset(os_aio_segment_wait_events[global_segment]); - - os_mutex_exit(array->mutex); - - os_event_wait(os_aio_segment_wait_events[global_segment]); - - goto restart; -} - -/************************************************************************** -Validates the consistency of an aio array. */ -static -bool -os_aio_array_validate( -/*==================*/ - /* out: TRUE if ok */ - os_aio_array_t* array) /* in: aio wait array */ -{ - os_aio_slot_t* slot; - ulint n_reserved = 0; - ulint i; - - ut_a(array); - - os_mutex_enter(array->mutex); - - ut_a(array->n_slots > 0); - ut_a(array->n_segments > 0); - - for (i = 0; i < array->n_slots; i++) { - slot = os_aio_array_get_nth_slot(array, i); - - if (slot->reserved) { - n_reserved++; - ut_a(slot->len > 0); - } - } - - ut_a(array->n_reserved == n_reserved); - - os_mutex_exit(array->mutex); - - return(TRUE); -} - -/************************************************************************** -Validates the consistency the aio system. */ - -bool -os_aio_validate(void) -/*=================*/ - /* out: TRUE if ok */ -{ - os_aio_array_validate(os_aio_read_array); - os_aio_array_validate(os_aio_write_array); - os_aio_array_validate(os_aio_ibuf_array); - os_aio_array_validate(os_aio_log_array); - os_aio_array_validate(os_aio_sync_array); - - return(TRUE); -} - -/************************************************************************** -Prints info of the aio arrays. */ - -void -os_aio_print(void) -/*==============*/ -{ - os_aio_array_t* array; - os_aio_slot_t* slot; - ulint n_reserved; - ulint i; - - array = os_aio_read_array; -loop: - ut_a(array); - - printf("INFO OF AN AIO ARRAY\n"); - - os_mutex_enter(array->mutex); - - ut_a(array->n_slots > 0); - ut_a(array->n_segments > 0); - - n_reserved = 0; - - for (i = 0; i < array->n_slots; i++) { - slot = os_aio_array_get_nth_slot(array, i); - - if (slot->reserved) { - n_reserved++; - printf("Reserved slot, messages %lx %lx\n", - slot->message1, slot->message2); - ut_a(slot->len > 0); - } - } - - ut_a(array->n_reserved == n_reserved); - - printf("Total of %lu reserved aio slots\n", n_reserved); - - os_mutex_exit(array->mutex); - - if (array == os_aio_read_array) { - array = os_aio_write_array; - - goto loop; - } - - if (array == os_aio_write_array) { - array = os_aio_ibuf_array; - - goto loop; - } - - if (array == os_aio_ibuf_array) { - array = os_aio_log_array; - - goto loop; - } - - if (array == os_aio_log_array) { - array = os_aio_sync_array; - - goto loop; - } -} - -/************************************************************************** -Checks that all slots in the system have been freed, that is, there are -no pending io operations. */ - -bool -os_aio_all_slots_free(void) -/*=======================*/ - /* out: TRUE if all free */ -{ - os_aio_array_t* array; - ulint n_res = 0; - - array = os_aio_read_array; - - os_mutex_enter(array->mutex); - - n_res += array->n_reserved; - - os_mutex_exit(array->mutex); - - array = os_aio_write_array; - - os_mutex_enter(array->mutex); - - n_res += array->n_reserved; - - os_mutex_exit(array->mutex); - - array = os_aio_ibuf_array; - - os_mutex_enter(array->mutex); - - n_res += array->n_reserved; - - os_mutex_exit(array->mutex); - - array = os_aio_log_array; - - os_mutex_enter(array->mutex); - - n_res += array->n_reserved; - - os_mutex_exit(array->mutex); - - array = os_aio_sync_array; - - os_mutex_enter(array->mutex); - - n_res += array->n_reserved; - - os_mutex_exit(array->mutex); - - if (n_res == 0) { - - return(TRUE); - } - - return(FALSE); -} diff --git a/innobase/os/ts/makefile b/innobase/os/ts/makefile deleted file mode 100644 index 0e145a14e7f..00000000000 --- a/innobase/os/ts/makefile +++ /dev/null @@ -1,20 +0,0 @@ - - - -include ..\..\makefile.i - -doall: tsos tsosaux - - -tsos: ..\os.lib tsos.c - $(CCOM) $(CFL) -I.. -I..\.. ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\os.lib tsos.c $(LFL) - -tsosaux: tsosaux.c - $(CCOM) $(CFL) -I.. -I..\.. ..\..\ut.lib ..\os.lib tsosaux.c $(LFL) - - - - - - - diff --git a/innobase/os/ts/tsos.c b/innobase/os/ts/tsos.c deleted file mode 100644 index ecc10b86d2f..00000000000 --- a/innobase/os/ts/tsos.c +++ /dev/null @@ -1,793 +0,0 @@ -/************************************************************************ -The test module for the operating system interface - -(c) 1995 Innobase Oy - -Created 9/27/1995 Heikki Tuuri -*************************************************************************/ - - -#include "../os0thread.h" -#include "../os0shm.h" -#include "../os0proc.h" -#include "../os0sync.h" -#include "../os0file.h" -#include "ut0ut.h" -#include "ut0mem.h" -#include "sync0sync.h" -#include "mem0mem.h" - -#define _WIN32_WINNT 0x0400 -#include "n:\program files\devstudio\vc\include\windows.h" -#include "n:\program files\devstudio\vc\include\winbase.h" - -ulint last_thr = 1; - -byte global_buf[4000000]; - -ulint* cache_buf; - -os_file_t file; -os_file_t file2; - -os_event_t gl_ready; - -mutex_t ios_mutex; -ulint ios; -ulint rnd = 9837497; - -/******************************************************************** -Start function for threads in test1. */ - -ulint -thread(void* arg) -/*==============*/ -{ - ulint i; - void* arg2; - ulint count = 0; - ulint n; - ulint rnd_loc; - byte local_buf[2000]; - - arg2 = arg; - - n = *((ulint*)arg); - -/* printf("Thread %lu started!\n", n); */ - - for (i = 0; i < 8000; i++) { - - rnd_loc = rnd; - rnd += 763482469; - - ut_memcpy(global_buf + (rnd_loc % 1500000) + 8200, local_buf, - 2000); - if (last_thr != n) { - count++; - last_thr = n; - } - - if (i % 32 == 0) { - os_thread_yield(); - } - } - - printf("Thread %lu exits: %lu thread switches noticed\n", n, count); - - return(0); -} - -/********************************************************************* -Test of the speed of wait for multiple events. */ - -void -testa1(void) -/*========*/ -{ - ulint i; - os_event_t arr[64]; - ulint tm, oldtm; - - printf("-------------------------------------------------\n"); - printf("TEST A1. Speed of waits\n"); - - for (i = 0; i < 64; i++) { - arr[i] = os_event_create(NULL); - ut_a(arr[i]); - } - - os_event_set(arr[1]); - - oldtm = ut_clock(); - - for (i = 0; i < 10000; i++) { - os_event_wait_multiple(4, arr); - } - - tm = ut_clock(); - - printf("Wall clock time for %lu multiple waits %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 10000; i++) { - os_event_wait(arr[1]); - } - - tm = ut_clock(); - - printf("Wall clock time for %lu single waits %lu millisecs\n", - i, tm - oldtm); - - - for (i = 0; i < 64; i++) { - os_event_free(arr[i]); - } -} - -/********************************************************************* -Test for threads. */ - -void -test1(void) -/*=======*/ -{ - os_thread_t thr[64]; - os_thread_id_t id[64]; - ulint n[64]; - ulint tm, oldtm; - ulint i, j; - - printf("-------------------------------------------\n"); - printf("OS-TEST 1. Test of thread switching through yield\n"); - - printf("Main thread %lu starts!\n", os_thread_get_curr_id()); - - for (j = 0; j < 2; j++) { - - oldtm = ut_clock(); - - for (i = 0; i < 64; i++) { - n[i] = i; - - thr[i] = os_thread_create(thread, n + i, id + i); -/* printf("Thread %lu created, id %lu \n", i, id[i]); */ - } - - for (i = 0; i < 64; i++) { - os_thread_wait(thr[i]); - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 64; i++) { - - thr[5] = os_thread_create(thread, n + 5, id + 5); - -/* printf("Thread created, id %lu \n", id[5]); */ - - os_thread_wait(thr[5]); - } - - tm = ut_clock(); - printf("Wall clock time for single thread test %lu milliseconds\n", - tm - oldtm); - } -} - -/********************************************************************* -Test for shared memory and process switching through yield. */ - -void -test2(void) -/*=======*/ -{ - os_shm_t shm; - ulint tm, oldtm; - ulint* pr_no; - ulint count; - ulint i; - bool ret; - os_process_t proc; - os_process_id_t proc_id; - - printf("-------------------------------------------\n"); - printf("OS-TEST 2. Test of process switching through yield\n"); - - shm = os_shm_create(1000, "TSOS_SHM"); - - pr_no = os_shm_map(shm); - - *pr_no = 1; - count = 0; - - ret = os_process_create("tsosaux.exe", NULL, &proc, &proc_id); - - printf("Last error: %lu\n", os_thread_get_last_error()); - - ut_a(ret); - - printf("Process 1 starts test!\n"); - - oldtm = ut_clock(); - - for (i = 0; i < 500000; i++) { - if (*pr_no != 1) { - count++; - *pr_no = 1; - } - - os_thread_yield(); - } - - tm = ut_clock(); - - printf("Process 1 finishes test: %lu process switches noticed\n", - count); - - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - os_shm_unmap(shm); - - os_shm_free(shm); -} - -#ifdef notdefined - -/********************************************************************* -Test for asynchronous file io. */ - -void -test3(void) -/*=======*/ -{ - ulint i; - ulint j; - void* mess; - bool ret; - void* buf; - ulint rnd; - ulint addr[64]; - ulint serv[64]; - ulint tm, oldtm; - - printf("-------------------------------------------\n"); - printf("OS-TEST 3. Test of asynchronous file io\n"); - - /* Align the buffer for file io */ - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - rnd = ut_time(); - - rnd = rnd * 3416133; - - printf("rnd seed %lu\n", rnd % 4900); - - oldtm = ut_clock(); - - for (i = 0; i < 32; i++) { - - ret = os_aio_read(file, buf, 8192 * (rnd % 4900), 0, - 8192, (void*)i); - ut_a(ret); - rnd += 1; - ret = os_aio_wait(0, &mess); - ut_a(ret); - } - - tm = ut_clock(); - printf("Wall clock time for synchr. io %lu milliseconds\n", - tm - oldtm); - - rnd = rnd * 3416133; - - printf("rnd seed %lu\n", rnd % 5000); - - oldtm = ut_clock(); - - for (j = 0; j < 5; j++) { - - rnd = rnd + 3416133; - - for (i = 0; i < 16; i++) { - ret = os_aio_read(file, buf, 8192 * (rnd % 5000), 0, 8192, - (void*)i); - addr[i] = rnd % 5000; - ut_a(ret); - rnd += 1; - } - - - for (i = 0; i < 16; i++) { - ret = os_aio_read(file, buf, 8192 * (rnd % 5000), 0, 8192, - (void*)i); - addr[i] = rnd % 5000; - ut_a(ret); - rnd += 1; - } - - rnd = rnd + 3416133; - - for (i = 0; i < 32; i++) { - ret = os_aio_wait(0, &mess); - ut_a(ret); - ut_a((ulint)mess < 64); - serv[(ulint)mess] = i; - } - } - tm = ut_clock(); - printf("Wall clock time for aio %lu milliseconds\n", tm - oldtm); - - rnd = rnd * 3416133; - - printf("rnd seed %lu\n", rnd % 4900); - - oldtm = ut_clock(); - -for (j = 0; j < 5; j++) { - - rnd = rnd + 3416133; - - for (i = 0; i < 1; i++) { - ret = os_aio_read(file, buf, 8192 * (rnd % 4900), 0, - 64 * 8192, (void*)i); - ut_a(ret); - rnd += 4; - ret = os_aio_wait(0, &mess); - ut_a(ret); - ut_a((ulint)mess < 64); - } -} - tm = ut_clock(); - printf("Wall clock time for synchr. io %lu milliseconds\n", - tm - oldtm); - - -/* - for (i = 0; i < 63; i++) { - printf("read %lu addr %lu served as %lu\n", - i, addr[i], serv[i]); - } -*/ - - ut_a(ret); -} - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = os_aio_wait(segment, &mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - ut_a(ret); -/* printf("Message for thread %lu %lu\n", segment, - (ulint)mess); */ - if ((ulint)mess == 3333) { - os_event_set(gl_ready); - } - } - - return(0); -} - -/************************************************************************ -Test of io-handler threads */ - -void -test4(void) -/*=======*/ -{ - ulint i; - ulint j; - bool ret; - void* buf; - ulint rnd; - ulint tm, oldtm; - os_thread_t thr[5]; - os_thread_id_t id[5]; - ulint n[5]; - - printf("-------------------------------------------\n"); - printf("OS-TEST 4. Test of asynchronous file io\n"); - - /* Align the buffer for file io */ - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - gl_ready = os_event_create(NULL); - ios = 0; - - sync_init(); - mem_init(); - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } - - rnd = 0; - - oldtm = ut_clock(); - -for (j = 0; j < 128; j++) { - - - for (i = 0; i < 32; i++) { - ret = os_aio_read(file, (byte*)buf + 8192 * (rnd % 100), - 8192 * (rnd % 4096), 0, - 8192, (void*)i); - ut_a(ret); - rnd += 1; - } - -/* - rnd += 67475941; - - for (i = 0; i < 1; i++) { - ret = os_aio_read(file2, buf, 8192 * (rnd % 5000), 0, - 8192, (void*)i); - ut_a(ret); - rnd += 1; - } -*/ -} - ret = os_aio_read(file, buf, 8192 * (rnd % 4096), 0, 8192, - (void*)3333); - ut_a(ret); - - ut_a(!os_aio_all_slots_free()); -/* - printf("Starting flush!\n"); - ret = os_file_flush(file); - ut_a(ret); - printf("Ending flush!\n"); -*/ - tm = ut_clock(); - - printf("All ios queued! N ios: %lu\n", ios); - - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - os_event_wait(gl_ready); - - tm = ut_clock(); - printf("N ios: %lu\n", ios); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - os_thread_sleep(2000000); - - printf("N ios: %lu\n", ios); - - ut_a(os_aio_all_slots_free()); -} - -/************************************************************************* -Initializes the asyncronous io system for tests. */ - -void -init_aio(void) -/*==========*/ -{ - bool ret; - ulint i; - void* buf; - void* mess; - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - os_aio_init(160, 5); - file = os_file_create("j:\\tsfile2", OS_FILE_CREATE, OS_FILE_TABLESPACE, - &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == OS_FILE_ALREADY_EXISTS); - - file = os_file_create("j:\\tsfile2", OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } else { - - for (i = 0; i < 4100; i++) { - ret = os_aio_write(file, buf, 8192 * i, 0, 8192, NULL); - ut_a(ret); - - ret = os_aio_wait(0, &mess); - - ut_a(ret); - ut_a(mess == NULL); - } - } - - file2 = os_file_create("F:\\tmp\\tsfile", OS_FILE_CREATE, - OS_FILE_TABLESPACE, - &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == OS_FILE_ALREADY_EXISTS); - - file2 = os_file_create("F:\\tmp\\tsfile", OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } else { - - for (i = 0; i < 5000; i++) { - ret = os_aio_write(file2, buf, 8192 * i, 0, 8192, NULL); - ut_a(ret); - - ret = os_aio_wait(0, &mess); - - ut_a(ret); - ut_a(mess == NULL); - } - } -} - -/************************************************************************ -Test of synchronous io */ - -void -test5(void) -/*=======*/ -{ - ulint i, j, k; - bool ret; - void* buf; - ulint rnd = 0; - ulint tm = 0; - ulint oldtm = 0; - os_file_t files[1000]; - char name[5]; - ulint err; - - printf("-------------------------------------------\n"); - printf("OS-TEST 5. Test of creating and opening of many files\n"); - - /* Align the buffer for file io */ - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - name[2] = '.'; - name[3] = 'd'; - name[4] = '\0'; - - oldtm = ut_clock(); - - for (j = 0; j < 20; j++) { - for (i = 0; i < 20; i++) { - name[0] = (char)(i + (ulint)'A'); - name[1] = (char)(j + (ulint)'A'); - files[j * 20 + i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_NORMAL, &ret); - if (!ret) { - err = os_file_get_last_error(); - } - ut_a(ret); - } - } - - for (k = 0; k < i * j; k++) { - ret = os_file_close(files[k]); - ut_a(ret); - } - - for (j = 0; j < 20; j++) { - for (i = 0; i < 20; i++) { - name[0] = (char)(i + (ulint)'A'); - name[1] = (char)(j + (ulint)'A'); - ret = os_file_delete(name); - ut_a(ret); - } - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); -} - -/************************************************************************ -Test of synchronous io */ - -void -test6(void) -/*=======*/ -{ - ulint i, j; - bool ret; - void* buf; - ulint rnd = 0; - ulint tm = 0; - ulint oldtm = 0; - os_file_t s_file; - - printf("-------------------------------------------\n"); - printf("OS-TEST 6. Test of synchronous io\n"); - - buf = (void*)(((ulint)global_buf + 6300) & (~0xFFF)); - - ret = os_file_close(file); - ut_a(ret); - - ret = os_file_close(file2); - ut_a(ret); - - s_file = os_file_create("tsfile", OS_FILE_OPEN, - OS_FILE_NORMAL, &ret); - if (!ret) { - printf("Error no %lu\n", os_file_get_last_error()); - } - - ut_a(ret); - - rnd = ut_time() * 6346353; - - oldtm = ut_clock(); - - for (j = 0; j < 100; j++) { - - rnd += 8072791; - - for (i = 0; i < 32; i++) { - ret = os_file_read(s_file, buf, 8192 * (rnd % 5000), 0, - 8192); - ut_a(ret); - rnd += 1; - } - } - - tm = ut_clock(); - - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); -} - -/************************************************************************ -Test of file size operations. */ - -void -test7(void) -/*=======*/ -{ - bool ret; - os_file_t f; - ulint len; - ulint high; - - printf("-------------------------------------------\n"); - printf("OS-TEST 7. Test of setting and getting file size\n"); - - - f = os_file_create("sizefile", OS_FILE_CREATE, OS_FILE_TABLESPACE, - &ret); - ut_a(ret); - - ret = os_file_get_size(f, &len, &high); - ut_a(ret); - - ut_a(len == 0); - ut_a(high == 0); - - ret = os_file_set_size(f, 5000000, 0); - ut_a(ret); - - ret = os_file_get_size(f, &len, &high); - ut_a(ret); - - ut_a(len == 5000000); - ut_a(high == 0); - - ret = os_file_set_size(f, 4000000, 0); - ut_a(ret); - - ret = os_file_get_size(f, &len, &high); - ut_a(ret); - - ut_a(len == 4000000); - ut_a(high == 0); - - ret = os_file_close(f); - ut_a(ret); - - ret = os_file_delete("sizefile"); - ut_a(ret); -} -#endif - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - ulint i; - CRITICAL_SECTION cs; - ulint sum; - ulint rnd; - - cache_buf = VirtualAlloc(NULL, 4 * 1024, MEM_COMMIT, - PAGE_READWRITE /* | PAGE_NOCACHE */); - oldtm = ut_clock(); - - sum = 0; - rnd = 0; - - for (i = 0; i < 1000000; i++) { - - sum += cache_buf[rnd * (16)]; - - rnd += 1; - - if (rnd > 7) { - rnd = 0; - } - } - - tm = ut_clock(); - - printf("Wall clock time for cache test %lu milliseconds\n", tm - oldtm); - - InterlockedExchange(&i, 5); - - InitializeCriticalSection(&cs); - - oldtm = ut_clock(); - - for (i = 0; i < 10000000; i++) { - - TryEnterCriticalSection(&cs); - - LeaveCriticalSection(&cs); - } - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - testa1(); - - test1(); - -/* test2(); */ - -/* init_aio(); */ -/* - test3(); -*/ -/* test4(); - - test5(); - - test6(); - - test7(); */ - - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} - diff --git a/innobase/os/ts/tsosaux.c b/innobase/os/ts/tsosaux.c deleted file mode 100644 index 8f7780844e9..00000000000 --- a/innobase/os/ts/tsosaux.c +++ /dev/null @@ -1,83 +0,0 @@ -/************************************************************************ -The test module for the operating system interface -Auxiliary executable run alongside tsos.exe to test -process switching speed - -(c) 1995 Innobase Oy - -Created 9/27/1995 Heikki Tuuri -*************************************************************************/ - - -#include "../os0thread.h" -#include "../os0shm.h" -#include "../os0proc.h" -#include "ut0ut.h" - -/********************************************************************* -Test for shared memory and process switching through yield. */ - -void -test2(void) -/*=======*/ -{ - os_shm_t shm; - ulint tm, oldtm; - ulint* pr_no; - ulint count; - ulint i; - - printf("-------------------------------------------\n"); - printf("OS-TEST 2. Test of process switching through yield\n"); - - - shm = os_shm_create(1000, "TSOS_SHM"); - - pr_no = os_shm_map(shm); - - count = 0; - - printf("Process 2 starts test!\n"); - - oldtm = ut_clock(); - - for (i = 0; i < 100000; i++) { - if (*pr_no != 2) { - count++; - *pr_no = 2; - } - os_thread_yield(); - } - - tm = ut_clock(); - - printf("Process 2 finishes test: %lu process switches noticed\n", - count); - - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - - - os_shm_unmap(shm); - - os_shm_free(shm); -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - oldtm = ut_clock(); - - test2(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); - - os_process_exit(0); -} diff --git a/innobase/page/ts/makefile b/innobase/page/ts/makefile deleted file mode 100644 index cf96509ee73..00000000000 --- a/innobase/page/ts/makefile +++ /dev/null @@ -1,16 +0,0 @@ - - - -include ..\..\makefile.i - -tspage: ..\page.lib tspage.c - $(CCOM) $(CFL) -I.. -I..\.. ..\page.lib ..\..\btr.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tspage.c $(LFL) - - - - - - - - - diff --git a/innobase/page/ts/tspage.c b/innobase/page/ts/tspage.c deleted file mode 100644 index 3b8869e5e14..00000000000 --- a/innobase/page/ts/tspage.c +++ /dev/null @@ -1,705 +0,0 @@ -/************************************************************************ -The test for the index page - -(c) 1994-1996 Innobase Oy - -Created 1/31/1994 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "fil0fil.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "..\page0page.h" -#include "..\page0cur.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 1 -#define N_FILES 2 -#define FILE_SIZE 1000 /* must be > 512 */ -#define POOL_SIZE 1000 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "j:\\tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[9] = (char)((ulint)'0' + k); - name[10] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/********************************************************************* -Test for index page. */ - -void -test1(void) -/*=======*/ -{ - page_t* page; - dtuple_t* tuple; - mem_heap_t* heap; - ulint i; - ulint rnd = 0; - rec_t* rec; - page_cur_t cursor; - dict_index_t* index; - dict_table_t* table; - buf_block_t* block; - buf_frame_t* frame; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 1. Basic test\n"); - - heap = mem_heap_create(0); - - table = dict_table_create("TS_TABLE1", 3); - - dict_table_add_col(table, "COL1", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL2", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL3", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - - ut_a(0 == dict_table_publish(table)); - - index = dict_index_create("TS_TABLE1", "IND1", 0, 3, 0); - - dict_index_add_field(index, "COL1", 0); - dict_index_add_field(index, "COL2", 0); - dict_index_add_field(index, "COL3", 0); - - ut_a(0 == dict_index_publish(index)); - - index = dict_index_get("TS_TABLE1", "IND1"); - ut_a(index); - - tuple = dtuple_create(heap, 3); - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 534671) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - -/* page_print_list(page, 151); */ - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 7771) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_get_n_recs(page) == 0); - - ut_a(page_validate(page, index)); - page = page_create(frame, &mtr); - - rnd = 311; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 217; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - page = page_create(frame, &mtr); - - rnd = 291; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 277; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - mem_heap_free(heap); -} - -/********************************************************************* -Test for index page. */ - -void -test2(void) -/*=======*/ -{ - page_t* page; - dtuple_t* tuple; - mem_heap_t* heap; - ulint i, j; - ulint rnd = 0; - rec_t* rec; - page_cur_t cursor; - dict_index_t* index; - dict_table_t* table; - buf_block_t* block; - buf_frame_t* frame; - ulint tm, oldtm; - byte buf[8]; - mtr_t mtr; - mtr_t mtr2; - - printf("-------------------------------------------------\n"); - printf("TEST 2. Speed test\n"); - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf, bigbuf + 800, 800); - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - rnd = 0; - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf + rnd, bigbuf + rnd + 800, 800); - rnd += 1600; - if (rnd > 995000) { - rnd = 0; - } - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - heap = mem_heap_create(0); - - table = dict_table_create("TS_TABLE2", 2); - - dict_table_add_col(table, "COL1", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL2", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - - ut_a(0 == dict_table_publish(table)); - - index = dict_index_create("TS_TABLE2", "IND2", 0, 2, 0); - - dict_index_add_field(index, "COL1", 0); - dict_index_add_field(index, "COL2", 0); - - ut_a(0 == dict_index_publish(index)); - - index = dict_index_get("TS_TABLE2", "IND2"); - ut_a(index); - - tuple = dtuple_create(heap, 3); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 5 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 200; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_get(0, 5, &mtr); - buf_page_s_lock(block, &mtr); - - page = buf_block_get_frame(block); - ut_a(page_validate(page, index)); - mtr_commit(&mtr); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 5 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 200; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for %lu empty loops with page create %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 5 * UNIV_DBC * UNIV_DBC; i++) { - - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - mtr_commit(&mtr); - - rnd = 100; - for (j = 0; j < 200; j++) { - mtr_start(&mtr2); - - block = buf_page_get(0, 5, &mtr2); - buf_page_x_lock(block, &mtr2); - - page = buf_block_get_frame(block); - - rnd = (rnd + 1) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr2); - ut_a(rec); - - mtr_commit(&mtr2); - } - } - - tm = ut_clock(); - printf( - "Wall time for sequential insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_get(0, 5, &mtr); - buf_page_s_lock(block, &mtr); - - page = buf_block_get_frame(block); - ut_a(page_validate(page, index)); - mtr_commit(&mtr); - - oldtm = ut_clock(); - - for (i = 0; i < 5 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 500; - for (j = 0; j < 200; j++) { - rnd = (rnd - 1) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for descend. seq. insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 5 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 200; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - - rnd = 677; - for (j = 0; j < 200; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - } - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insert and delete of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 200; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - ut_a(page_validate(page, index)); - mtr_print(&mtr); - - oldtm = ut_clock(); - - for (i = 0; i < 5 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 200; j++) { -/* rnd = (rnd + 54841) % 1000;*/ - dtuple_gen_test_tuple3(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - } - } - - tm = ut_clock(); - printf("Wall time for search of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 5 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 200; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple3(tuple, rnd, buf); - } - } - - tm = ut_clock(); - printf("Wall time for %lu empty loops %lu milliseconds\n", - i * j, tm - oldtm); - mtr_commit(&mtr); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - sync_init(); - mem_init(); - os_aio_init(160, 5); - fil_init(25); - buf_pool_init(100, 100); - dict_init(); - log_init(); - - create_files(); - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(); - test2(); - - mem_print_info(); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/que/que0que.c b/innobase/que/que0que.c index 7e4babd43ef..e52afb0c9b1 100644 --- a/innobase/que/que0que.c +++ b/innobase/que/que0que.c @@ -7,7 +7,7 @@ Created 5/27/1996 Heikki Tuuri *******************************************************/ #include "que0que.h" - + #ifdef UNIV_NONINL #include "que0que.ic" #endif diff --git a/innobase/rem/ts/makefile b/innobase/rem/ts/makefile deleted file mode 100644 index c429afa273e..00000000000 --- a/innobase/rem/ts/makefile +++ /dev/null @@ -1,16 +0,0 @@ - - - -include ..\..\makefile.i - -tsrem: ..\rem.lib tsrem.c - $(CCOM) $(CFL) -I.. -I..\.. ..\rem.lib ..\..\page.lib ..\..\mtr.lib ..\..\btr.lib ..\..\log.lib ..\..\dyn.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tsrem.c $(LFL) - - - - - - - - - diff --git a/innobase/rem/ts/tsrem.c b/innobase/rem/ts/tsrem.c deleted file mode 100644 index 4f2bdde0068..00000000000 --- a/innobase/rem/ts/tsrem.c +++ /dev/null @@ -1,464 +0,0 @@ -/************************************************************************ -The test for the record manager - -(c) 1994-1996 Innobase Oy - -Created 1/25/1994 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "mem0mem.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "fil0fil.h" -#include "../rem0rec.h" -#include "../rem0cmp.h" - -byte buf1[100000]; - -/********************************************************************* -Test for data tuples. */ - -void -test1(void) -/*=======*/ -{ - dtype_t* type; - dtuple_t* tuple, *tuple2; - dfield_t* field; - mem_heap_t* heap; - ulint i, j; - ulint n; - char* p_Pascal; - char* p_Cobol; - - heap = mem_heap_create(0); - - printf("-------------------------------------------\n"); - printf("DATA TUPLE-TEST 1. Basic tests.\n"); - - tuple = dtuple_create(heap, 2); - - field = dtuple_get_nth_field(tuple, 0); - dfield_set_data(field, "Pascal", 7); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 7, 0); - - field = dtuple_get_nth_field(tuple, 1); - dfield_set_data(field, "Cobol", 6); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 6, 0); - - dtuple_validate(tuple); - dtuple_print(tuple); - - tuple2 = dtuple_create(heap, 10); - - for (i = 0; i < 10; i++) { - field = dtuple_get_nth_field(tuple2, i); - dfield_set_data(field, NULL, UNIV_SQL_NULL); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, - 6, 0); - } - - dtuple_print(tuple2); - - printf("-------------------------------------------\n"); - printf("DATA TUPLE-TEST 2. Accessor function tests.\n"); - - tuple = dtuple_create(heap, 2); - - p_Pascal = "Pascal"; - p_Cobol = "Cobol"; - - field = dtuple_get_nth_field(tuple, 0); - dfield_set_data(field, p_Pascal, 7); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 7, 0); - - field = dtuple_get_nth_field(tuple, 1); - dfield_set_data(field, p_Cobol, 6); - dtype_set(dfield_get_type(field), DATA_VARCHAR, DATA_ENGLISH, 16, 3); - - ut_a(dtuple_get_n_fields(tuple) == 2); - - field = dtuple_get_nth_field(tuple, 0); - ut_a(p_Pascal == dfield_get_data(field)); - ut_a(7 == dfield_get_len(field)); - type = dfield_get_type(field); - ut_a(type->mtype == DATA_CHAR); - ut_a(type->prtype == DATA_ENGLISH); - ut_a(type->len == 7); - ut_a(type->prec == 0); - - field = dtuple_get_nth_field(tuple, 1); - ut_a(p_Cobol == dfield_get_data(field)); - ut_a(6 == dfield_get_len(field)); - type = dfield_get_type(field); - ut_a(type->mtype == DATA_VARCHAR); - ut_a(type->prtype == DATA_ENGLISH); - ut_a(type->len == 16); - ut_a(type->prec == 3); - - printf("-------------------------------------------\n"); - printf("DATA TYPE-TEST 3. Other function tests\n"); - - ut_a(dtuple_get_data_size(tuple) == 13); - - ut_a(dtuple_fold(tuple, 2) == dtuple_fold(tuple, 2)); - ut_a(dtuple_fold(tuple, 1) != dtuple_fold(tuple, 2)); - - printf("-------------------------------------------\n"); - printf("DATA TUPLE-TEST 4. Random tuple generation test\n"); - - for (i = 0; i < 500; i++) { - tuple = dtuple_gen_rnd_tuple(heap); - printf("%lu ", i); - - dtuple_validate(tuple); - n = dtuple_get_n_fields(tuple); - - if (n < 25) { - tuple2 = dtuple_create(heap, n); - for (j = 0; j < n; j++) { - dfield_copy( - dtuple_get_nth_field(tuple2, j), - dtuple_get_nth_field(tuple, j)); - } - dtuple_validate(tuple2); - - ut_a(dtuple_fold(tuple, n) == - dtuple_fold(tuple2, n)); - } - } - - mem_print_info(); - mem_heap_free(heap); -} - -/********************************************************************** -Test for physical records. */ - -void -test2(void) -/*=======*/ -{ - dtuple_t* tuple, *tuple2; - dfield_t* field; - mem_heap_t* heap; - ulint i, n; - char* p_Pascal; - char* p_Cobol; - rec_t* rec, *rec2; - byte* data; - ulint len; - byte* buf; - - heap = mem_heap_create(0); - - printf("-------------------------------------------\n"); - printf("REC-TEST 1. Basic tests.\n"); - - tuple = dtuple_create(heap, 2); - - p_Pascal = "Pascal"; - p_Cobol = "Cobol"; - - field = dtuple_get_nth_field(tuple, 0); - dfield_set_data(field, "Pascal", 7); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 7, 0); - - field = dtuple_get_nth_field(tuple, 1); - dfield_set_data(field, "Cobol", 6); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 6, 0); - - tuple2 = dtuple_create(heap, 37); - - for (i = 0; i < 37; i++) { - field = dtuple_get_nth_field(tuple2, i); - dfield_set_data(field, NULL, UNIV_SQL_NULL); - dtype_set(dfield_get_type(field), DATA_CHAR, - DATA_ENGLISH, 6, 0); - } - - rec = rec_convert_dtuple_to_rec(buf1, tuple); - - rec_validate(rec); - rec_print(rec); - - rec2 = rec_convert_dtuple_to_rec(buf1 + 1000, tuple2); - - rec_validate(rec2); - - data = rec_get_nth_field(rec, 0, &len); - - ut_a(0 == memcmp(p_Pascal, data, 7)); - ut_a(len == 7); - - data = rec_get_nth_field(rec, 1, &len); - - ut_a(0 == memcmp(p_Cobol, data, 6)); - ut_a(len == 6); - - ut_a(2 == rec_get_n_fields(rec)); - - for (i = 0; i < 37; i++) { - data = rec_get_nth_field(rec2, i, &len); - ut_a(len == UNIV_SQL_NULL); - } - - printf("-------------------------------------------\n"); - printf("REC-TEST 2. Test of accessor functions\n"); - - rec_set_next_offs(rec, 8190); - rec_set_n_owned(rec, 15); - rec_set_heap_no(rec, 0); - - ut_a(rec_get_next_offs(rec) == 8190); - ut_a(rec_get_n_owned(rec) == 15); - ut_a(rec_get_heap_no(rec) == 0); - - rec_set_next_offs(rec, 1); - rec_set_n_owned(rec, 1); - rec_set_heap_no(rec, 8190); - - ut_a(rec_get_next_offs(rec) == 1); - ut_a(rec_get_n_owned(rec) == 1); - ut_a(rec_get_heap_no(rec) == 8190); - - buf = mem_heap_alloc(heap, 6); - - rec_copy_nth_field(buf, rec, 1, &len); - - ut_a(ut_memcmp(p_Cobol, buf, len) == 0); - ut_a(len == 6); - - rec_set_nth_field(rec, 1, "Algol", 6); - - rec_validate(rec); - - rec_copy_nth_field(buf, rec, 1, &len); - - ut_a(ut_memcmp("Algol", buf, len) == 0); - ut_a(len == 6); - - ut_a(rec_get_data_size(rec) == 13); - ut_a((ulint)(rec_get_end(rec) - rec) == 13); - ut_a(14 == (ulint)(rec - rec_get_start(rec))); - - ut_a(rec_get_size(rec) == 27); - - mem_heap_free(heap); - - printf("-------------------------------------------\n"); - printf("REC-TEST 3. Massive test of conversions \n"); - - heap = mem_heap_create(0); - - for (i = 0; i < 100; i++) { - - tuple = dtuple_gen_rnd_tuple(heap); - - if (i % 10 == 0) { - printf("%lu ", i); - } - - if (i % 10 == 0) { - printf( - "data tuple generated: %lu fields, data size %lu\n", - dtuple_get_n_fields(tuple), - dtuple_get_data_size(tuple)); - } - - dtuple_validate(tuple); - - rec = rec_convert_dtuple_to_rec(buf1, tuple); - - rec_validate(rec); - - n = dtuple_get_n_fields(tuple); - - ut_a(cmp_dtuple_rec_prefix_equal(tuple, rec, n)); - ut_a(dtuple_fold(tuple, n) == rec_fold(rec, n)); - ut_a(rec_get_converted_size(tuple) == rec_get_size(rec)); - ut_a(rec_get_data_size(rec) == dtuple_get_data_size(tuple)); - } - - mem_print_info(); - mem_heap_free(heap); -} - -/********************************************************************** -Test for comparisons. */ - -void -test3(void) -/*=======*/ -{ - dtuple_t* tuple, *tuple2, *tuple3; - dfield_t* field; - mem_heap_t* heap; - ulint i, j; - ulint field_match, byte_match; - rec_t* rec; - rec_t* rec2; - ulint tm, oldtm; - dict_index_t* index; - dict_table_t* table; - - heap = mem_heap_create(0); - - printf("-------------------------------------------\n"); - printf("CMP-TEST 1. Basic tests.\n"); - - tuple = dtuple_create(heap, 2); - - field = dtuple_get_nth_field(tuple, 0); - dfield_set_data(field, "Pascal", 7); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 7, 0); - - field = dtuple_get_nth_field(tuple, 1); - dfield_set_data(field, "Cobol", 6); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 6, 0); - - tuple2 = dtuple_create(heap, 2); - - field = dtuple_get_nth_field(tuple2, 0); - dfield_set_data(field, "Pascal", 7); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 7, 0); - - field = dtuple_get_nth_field(tuple2, 1); - dfield_set_data(field, "Cobom", 6); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 6, 0); - - tuple3 = dtuple_create(heap, 2); - - field = dtuple_get_nth_field(tuple3, 0); - dfield_set_data(field, "PaSCal", 7); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 7, 0); - - field = dtuple_get_nth_field(tuple3, 1); - dfield_set_data(field, "CobOL", 6); - dtype_set(dfield_get_type(field), DATA_CHAR, DATA_ENGLISH, 6, 0); - - rec = rec_convert_dtuple_to_rec(buf1, tuple); - - rec_validate(rec); - - ut_a(!cmp_dtuple_rec_prefix_equal(tuple2, rec, 2)); - ut_a(cmp_dtuple_rec_prefix_equal(tuple, rec, 2)); - ut_a(cmp_dtuple_rec_prefix_equal(tuple3, rec, 2)); - - oldtm = ut_clock(); - j = 0; - for (i = 0; i < 1000; i++) { - field_match = 1; - byte_match = 4; - if (1 == cmp_dtuple_rec_with_match(tuple2, rec, - &field_match, &byte_match)) { - j++; - } - } - tm = ut_clock(); - printf("Time for fast comp. %lu records = %lu\n", j, tm - oldtm); - - ut_a(field_match == 1); - ut_a(byte_match == 4); - - oldtm = ut_clock(); - j = 0; - for (i = 0; i < 1000; i++) { - field_match = 0; - byte_match = 0; - if (1 == cmp_dtuple_rec_with_match(tuple2, rec, - &field_match, &byte_match)) { - j++; - } - } - tm = ut_clock(); - printf("Time for test comp. %lu records = %lu\n", j, tm - oldtm); - - ut_a(field_match == 1); - ut_a(byte_match == 4); - - printf("-------------------------------------------\n"); - printf( - "CMP-TEST 2. A systematic test of comparisons and conversions\n"); - - tuple = dtuple_create(heap, 3); - tuple2 = dtuple_create(heap, 3); - - table = dict_table_create("TS_TABLE1", 3); - - dict_table_add_col(table, "COL1", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL2", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL3", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - - ut_a(0 == dict_table_publish(table)); - - index = dict_index_create("TS_TABLE1", "IND1", 0, 3, 0); - - dict_index_add_field(index, "COL1", 0); - dict_index_add_field(index, "COL2", 0); - dict_index_add_field(index, "COL3", 0); - - ut_a(0 == dict_index_publish(index)); - - index = dict_index_get("TS_TABLE1", "IND1"); - ut_a(index); - - /* Compare all test data tuples to each other */ - for (i = 0; i < 512; i++) { - dtuple_gen_test_tuple(tuple, i); - rec = rec_convert_dtuple_to_rec(buf1, tuple); - ut_a(rec_validate(rec)); - - ut_a(0 == cmp_dtuple_rec(tuple, rec)); - - for (j = 0; j < 512; j++) { - dtuple_gen_test_tuple(tuple2, j); - ut_a(dtuple_validate(tuple2)); - - rec2 = rec_convert_dtuple_to_rec(buf1 + 500, tuple2); - - if (j < i) { - ut_a(-1 == cmp_dtuple_rec(tuple2, rec)); - ut_a(-1 == cmp_rec_rec(rec2, rec, index)); - } else if (j == i) { - ut_a(0 == cmp_dtuple_rec(tuple2, rec)); - ut_a(0 == cmp_rec_rec(rec2, rec, index)); - } else if (j > i) { - ut_a(1 == cmp_dtuple_rec(tuple2, rec)); - ut_a(1 == cmp_rec_rec(rec2, rec, index)); - } - } - } - mem_heap_free(heap); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - sync_init(); - mem_init(); - fil_init(25); - buf_pool_init(100, 100); - dict_init(); - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(); - test2(); - test3(); - - tm = ut_clock(); - printf("CPU time for test %lu microseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/row/ts/makefile b/innobase/row/ts/makefile deleted file mode 100644 index 589db50d4ed..00000000000 --- a/innobase/row/ts/makefile +++ /dev/null @@ -1,16 +0,0 @@ - - - -include ..\..\makefile.i - -tstcur: ..\tcur.lib tstcur.c - $(CCOM) $(CFL) -I.. -I..\.. ..\tcur.lib ..\..\trx.lib ..\..\btr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tstcur.c $(LFL) - - - - - - - - - diff --git a/innobase/row/ts/tstcur.c b/innobase/row/ts/tstcur.c deleted file mode 100644 index f5a5eb1f9f3..00000000000 --- a/innobase/row/ts/tstcur.c +++ /dev/null @@ -1,1087 +0,0 @@ -/************************************************************************ -Test for the index system - -(c) 1994-1996 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "rem0rec.h" -#include "..\tcur0ins.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 1 -#define N_FILES 1 -#define FILE_SIZE 4000 /* must be > 512 */ -#define POOL_SIZE 1000 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space header of space 0. */ - -void -init_space(void) -/*============*/ -{ - mtr_t mtr; - - printf("Init space header\n"); - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -Test for index page. */ - -void -test1(void) -/*=======*/ -{ - dtuple_t* tuple; - mem_heap_t* heap; - mem_heap_t* heap2; - ulint rnd = 0; - dict_index_t* index; - dict_table_t* table; - byte buf[16]; - ulint i, j; - ulint tm, oldtm; - trx_t* trx; -/* dict_tree_t* tree;*/ - btr_pcur_t pcur; - btr_pcur_t pcur2; - mtr_t mtr; - mtr_t mtr2; - byte* field; - ulint len; - dtuple_t* search_tuple; - dict_tree_t* index_tree; - rec_t* rec; - - UT_NOT_USED(len); - UT_NOT_USED(field); - UT_NOT_USED(pcur2); -/* - printf("\n\n\nPress 2 x enter to start test\n"); - - while (EOF == getchar()) { - - } - - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(1024); - heap2 = mem_heap_create(1024); - - trx = trx_start(ULINT_UNDEFINED); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - - ut_a(TRUE == dict_create_table(table, trx)); - - index = dict_mem_index_create("TS_TABLE1", "IND1", 75046, - DICT_CLUSTERED, 2); - - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - ut_a(TRUE == dict_create_index(index, trx)); - - trx_commit(trx); - - trx = trx_start(ULINT_UNDEFINED); - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - ut_a(TRUE == dict_create_index(index, trx)); - - trx_commit(trx); - - trx = trx_start(ULINT_UNDEFINED); - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - ut_a(TRUE == dict_create_index(index, trx)); - - trx_commit(trx); -/* - tree = dict_index_get_tree(dict_table_get_first_index(table)); - - btr_print_tree(tree, 10); -*/ - dict_table_print(table); - - /*---------------------------------------------------------*/ -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 2. INSERT 1 ROW TO THE TABLE\n"); - - trx = trx_start(ULINT_UNDEFINED); - - tuple = dtuple_create(heap, 3); - - table = dict_table_get("TS_TABLE1", trx); - - dtuple_gen_test_tuple3(tuple, 0, buf); - tcur_insert(tuple, table, heap2, trx); - - trx_commit(trx); -/* - tree = dict_index_get_tree(dict_table_get_first_index(table)); - - btr_print_tree(tree, 10); -*/ -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 3. INSERT MANY ROWS TO THE TABLE IN A SINGLE TRX\n"); - - rnd = 0; - oldtm = ut_clock(); - - trx = trx_start(ULINT_UNDEFINED); - for (i = 0; i < 300 * UNIV_DBC * UNIV_DBC; i++) { - - if (i % 5000 == 0) { - /* dict_table_print(table); - buf_print(); - buf_LRU_print(); - printf("%lu rows inserted\n", i); */ - } - - table = dict_table_get("TS_TABLE1", trx); - - if (i == 2180) { - rnd = rnd % 200000; - } - - rnd = (rnd + 1) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - tcur_insert(tuple, table, heap2, trx); - - mem_heap_empty(heap2); - - if (i % 4 == 3) { - } - } - trx_commit(trx); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("%lu rows inserted\n", i); -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 4. PRINT PART OF CONTENTS OF EACH INDEX TREE\n"); - -/* - mem_print_info(); -*/ - -/* - tree = dict_index_get_tree(dict_table_get_first_index(table)); - - btr_print_tree(tree, 10); - - tree = dict_index_get_tree(dict_table_get_next_index( - dict_table_get_first_index(table))); - - btr_print_tree(tree, 5); -*/ -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ -/* mem_print_info(); */ - - os_thread_sleep(5000000); - - for (j = 0; j < 5; j++) { - printf("-------------------------------------------------\n"); - printf("TEST 5. CALCULATE THE JOIN OF THE TABLE WITH ITSELF\n"); - - i = 0; - - oldtm = ut_clock(); - - mtr_start(&mtr); - - index_tree = dict_index_get_tree(UT_LIST_GET_FIRST(table->indexes)); - - search_tuple = dtuple_create(heap, 2); - - dtuple_gen_search_tuple3(search_tuple, i, buf); - - btr_pcur_open(index_tree, search_tuple, PAGE_CUR_GE, - BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - while (!btr_pcur_is_after_last_in_tree(&pcur, &mtr)) { - - if (i % 20000 == 0) { - printf("%lu rows joined\n", i); - } - - index_tree = dict_index_get_tree( - UT_LIST_GET_FIRST(table->indexes)); - - rec = btr_pcur_get_rec(&pcur); - - rec_copy_prefix_to_dtuple(search_tuple, rec, 2, heap2); - - mtr_start(&mtr2); - - btr_pcur_open(index_tree, search_tuple, PAGE_CUR_GE, - BTR_SEARCH_LEAF, &pcur2, &mtr2); - - btr_pcur_move_to_next(&pcur2, &mtr2); - - rec = btr_pcur_get_rec(&pcur2); - - field = rec_get_nth_field(rec, 1, &len); - - ut_a(len == 8); - - ut_a(ut_memcmp(field, dfield_get_data( - dtuple_get_nth_field(search_tuple, 1)), - len) == 0); - - btr_pcur_close(&pcur2, &mtr); - - mem_heap_empty(heap2); - - mtr_commit(&mtr2); - - btr_pcur_store_position(&pcur, &mtr); - mtr_commit(&mtr); - - mtr_start(&mtr); - - btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_move_to_next(&pcur, &mtr); - i++; - } - - btr_pcur_close(&pcur, &mtr); - mtr_commit(&mtr); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("%lu rows joined\n", i); - } - - oldtm = ut_clock(); - -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 6. INSERT MANY ROWS TO THE TABLE IN SEPARATE TRXS\n"); - - rnd = 200000; - - for (i = 0; i < 350; i++) { - - if (i % 4 == 0) { - } - trx = trx_start(ULINT_UNDEFINED); - - table = dict_table_get("TS_TABLE1", trx); - - if (i == 2180) { - rnd = rnd % 200000; - } - - rnd = (rnd + 1) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - tcur_insert(tuple, table, heap2, trx); - - trx_commit(trx); - - mem_heap_empty(heap2); - if (i % 4 == 3) { - } - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("%lu rows inserted in %lu transactions\n", i, i); -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 7. PRINT MEMORY ALLOCATION INFO\n"); - - mem_print_info(); -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 8. PRINT SEMAPHORE INFO\n"); - - sync_print(); - - - -#ifdef notdefined - rnd = 90000; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - if (i == 50000) { - rnd = rnd % 200000; - } - - rnd = (rnd + 595659561) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - btr_pcur_open(tree, tuple, PAGE_CUR_GE, - BTR_SEARCH_LEAF, &cursor, &mtr); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - rnd = (rnd + 35608971) % 200000 + 1; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - -/* btr_print_tree(tree, 3); */ - -#endif - mem_heap_free(heap); -} - - -#ifdef notdefined - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 534671) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - -/* page_print_list(page, 151); */ - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 7771) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_get_n_recs(page) == 0); - - ut_a(page_validate(page, index)); - page = page_create(frame, &mtr); - - rnd = 311; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 217; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - page = page_create(frame, &mtr); - - rnd = 291; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 277; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - mem_heap_free(heap); -} - -/********************************************************************* -Test for index page. */ - -void -test2(void) -/*=======*/ -{ - page_t* page; - dtuple_t* tuple; - mem_heap_t* heap; - ulint i, j; - ulint rnd = 0; - rec_t* rec; - page_cur_t cursor; - dict_index_t* index; - dict_table_t* table; - buf_block_t* block; - buf_frame_t* frame; - ulint tm, oldtm; - byte buf[8]; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2. Speed test\n"); - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf, bigbuf + 800, 800); - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - rnd = 0; - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf + rnd, bigbuf + rnd + 800, 800); - rnd += 1600; - if (rnd > 995000) { - rnd = 0; - } - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - heap = mem_heap_create(0); - - table = dict_table_create("TS_TABLE2", 2); - - dict_table_add_col(table, "COL1", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL2", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - - ut_a(0 == dict_table_publish(table)); - - index = dict_index_create("TS_TABLE2", "IND2", 0, 2, 0); - - dict_index_add_field(index, "COL1", 0); - dict_index_add_field(index, "COL2", 0); - - ut_a(0 == dict_index_publish(index)); - - index = dict_index_get("TS_TABLE2", "IND2"); - ut_a(index); - - tuple = dtuple_create(heap, 2); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_get(0, 5, &mtr); - buf_page_s_lock(block, &mtr); - - page = buf_block_get_frame(block); - ut_a(page_validate(page, index)); - mtr_commit(&mtr); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for %lu empty loops with page create %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 100; - for (j = 0; j < 250; j++) { - rnd = (rnd + 1) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for sequential insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 500; - for (j = 0; j < 250; j++) { - rnd = (rnd - 1) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for descend. seq. insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - } - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insert and delete of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - ut_a(page_validate(page, index)); - mtr_print(&mtr); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - } - } - - tm = ut_clock(); - printf("Wall time for search of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - } - } - - tm = ut_clock(); - printf("Wall time for %lu empty loops %lu milliseconds\n", - i * j, tm - oldtm); - mtr_commit(&mtr); -} - -#endif - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - mtr_t mtr; - - sync_init(); - mem_init(); - os_aio_init(160, 5); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - - create_files(); - init_space(); - - mtr_start(&mtr); - - trx_sys_create(&mtr); - dict_create(&mtr); - - mtr_commit(&mtr); - - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(); - -/* mem_print_info(); */ - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/srv/srv0srv.c b/innobase/srv/srv0srv.c index 4ff9a9ce1f7..88809ecbd09 100644 --- a/innobase/srv/srv0srv.c +++ b/innobase/srv/srv0srv.c @@ -883,122 +883,6 @@ srv_release_max_if_no_queries(void) mutex_exit(&kernel_mutex); } -#ifdef notdefined -/*********************************************************************** -Releases one utility thread if no queries are active and -the high-water mark 2 for the utility is exceeded. */ -static -void -srv_release_one_if_no_queries(void) -/*===============================*/ -{ - ulint m; - ulint type; - - mutex_enter(&kernel_mutex); - - if (srv_n_threads_active[SRV_COM] > 0) { - mutex_exit(&kernel_mutex); - - return; - } - - type = SRV_RECOVERY; - - m = 1; - - if ((srv_meter[type] > srv_meter_high_water2[type]) - && (srv_n_threads_active[type] < m)) { - - srv_release_threads(type, m - srv_n_threads_active[type]); - - printf("Releasing one background\n"); - } - - mutex_exit(&kernel_mutex); -} - -/*********************************************************************** -Decrements the utility meter by the value given and suspends the calling -thread, which must be an utility thread of the type given, if necessary. */ -static -void -srv_decrement_meter( -/*================*/ - ulint type, /* in: utility type */ - ulint n) /* in: value to subtract from meter */ -{ - ulint opt; - os_event_t event; - - mutex_enter(&kernel_mutex); - - if (srv_meter[type] < n) { - srv_meter[type] = 0; - } else { - srv_meter[type] -= n; - } - - opt = srv_max_n_utilities(type); - - if (opt < srv_n_threads_active[type]) { - - event = srv_suspend_thread(); - mutex_exit(&kernel_mutex); - - os_event_wait(event); - } else { - mutex_exit(&kernel_mutex); - } -} -#endif - -/************************************************************************* -Implements the server console. */ - -ulint -srv_console( -/*========*/ - /* out: return code, not used */ - void* arg) /* in: argument, not used */ -{ - char command[256]; - - UT_NOT_USED(arg); - - mutex_enter(&kernel_mutex); - srv_table_reserve_slot(SRV_CONSOLE); - mutex_exit(&kernel_mutex); - - os_event_wait(srv_sys->operational); - - for (;;) { - scanf("%s", command); - - srv_inc_thread_count(SRV_CONSOLE); - - if (command[0] == 'c') { - printf("Making checkpoint\n"); - - log_make_checkpoint_at(ut_dulint_max, TRUE); - - printf("Checkpoint completed\n"); - - } else if (command[0] == 'd') { - srv_sim_disk_wait_pct = atoi(command + 1); - - printf( - "Starting disk access simulation with pct %lu\n", - (ulong) srv_sim_disk_wait_pct); - } else { - printf("\nNot supported!\n"); - } - - srv_dec_thread_count(SRV_CONSOLE); - } - - return(0); /* Not reached */ -} /************************************************************************* Creates the first communication endpoint for the server. This @@ -1028,69 +912,6 @@ srv_communication_init( ut_a(ret == 0); } -#ifdef notdefined - -/************************************************************************* -Implements the recovery utility. */ -static -ulint -srv_recovery_thread( -/*================*/ - /* out: return code, not used */ - void* arg) /* in: not used */ -{ - ulint slot_no; - os_event_t event; - - UT_NOT_USED(arg); - - slot_no = srv_table_reserve_slot(SRV_RECOVERY); - - os_event_wait(srv_sys->operational); - - for (;;) { - /* Finish a possible recovery */ - - srv_inc_thread_count(SRV_RECOVERY); - -/* recv_recovery_from_checkpoint_finish(); */ - - srv_dec_thread_count(SRV_RECOVERY); - - mutex_enter(&kernel_mutex); - event = srv_suspend_thread(); - mutex_exit(&kernel_mutex); - - /* Wait for somebody to release this thread; (currently, this - should never be released) */ - - os_event_wait(event); - } - - return(0); -} - -/************************************************************************* -Implements the purge utility. */ - -ulint -srv_purge_thread( -/*=============*/ - /* out: return code, not used */ - void* arg) /* in: not used */ -{ - UT_NOT_USED(arg); - - os_event_wait(srv_sys->operational); - - for (;;) { - trx_purge(); - } - - return(0); -} -#endif /* notdefined */ - /************************************************************************* Creates the utility threads. */ @@ -1120,58 +941,6 @@ srv_create_utility_threads(void) ut_a(thread); */ } -#ifdef notdefined -/************************************************************************* -Implements the communication threads. */ -static -ulint -srv_com_thread( -/*===========*/ - /* out: return code; not used */ - void* arg) /* in: not used */ -{ - byte* msg_buf; - byte* addr_buf; - ulint msg_len; - ulint addr_len; - ulint ret; - - UT_NOT_USED(arg); - - srv_table_reserve_slot(SRV_COM); - - os_event_wait(srv_sys->operational); - - msg_buf = mem_alloc(com_endpoint_get_max_size(srv_sys->endpoint)); - addr_buf = mem_alloc(COM_MAX_ADDR_LEN); - - for (;;) { - ret = com_recvfrom(srv_sys->endpoint, msg_buf, - com_endpoint_get_max_size(srv_sys->endpoint), - &msg_len, (char*)addr_buf, COM_MAX_ADDR_LEN, - &addr_len); - ut_a(ret == 0); - - srv_inc_thread_count(SRV_COM); - - sess_process_cli_msg(msg_buf, msg_len, addr_buf, addr_len); - -/* srv_increment_meter(SRV_RECOVERY, 1); */ - - srv_dec_thread_count(SRV_COM); - - /* Release one utility thread for each utility if - high water mark 2 is exceeded and there are no - active queries. This is done to utilize possible - quiet time in the server. */ - - srv_release_one_if_no_queries(); - } - - return(0); -} -#endif - /************************************************************************* Creates the communication threads. */ @@ -1191,53 +960,6 @@ srv_create_com_threads(void) } } -#ifdef notdefined -/************************************************************************* -Implements the worker threads. */ -static -ulint -srv_worker_thread( -/*==============*/ - /* out: return code, not used */ - void* arg) /* in: not used */ -{ - os_event_t event; - - UT_NOT_USED(arg); - - srv_table_reserve_slot(SRV_WORKER); - - os_event_wait(srv_sys->operational); - - for (;;) { - mutex_enter(&kernel_mutex); - event = srv_suspend_thread(); - mutex_exit(&kernel_mutex); - - /* Wait for somebody to release this thread */ - os_event_wait(event); - - srv_inc_thread_count(SRV_WORKER); - - /* Check in the server task queue if there is work for this - thread, and do the work */ - - srv_que_task_queue_check(); - - srv_dec_thread_count(SRV_WORKER); - - /* Release one utility thread for each utility if - high water mark 2 is exceeded and there are no - active queries. This is done to utilize possible - quiet time in the server. */ - - srv_release_one_if_no_queries(); - } - - return(0); -} -#endif - /************************************************************************* Creates the worker threads. */ @@ -1258,403 +980,6 @@ srv_create_worker_threads(void) } } -#ifdef notdefined -/************************************************************************* -Reads a keyword and a value from a file. */ - -ulint -srv_read_init_val( -/*==============*/ - /* out: DB_SUCCESS or error code */ - FILE* initfile, /* in: file pointer */ - char* keyword, /* in: keyword before value(s), or NULL if - no keyword read */ - char* str_buf, /* in/out: buffer for a string value to read, - buffer size must be 10000 bytes, if NULL - then not read */ - ulint* num_val, /* out: numerical value to read, if NULL - then not read */ - ibool print_not_err) /* in: if TRUE, then we will not print - error messages to console */ -{ - ulint ret; - char scan_buf[10000]; - - if (keyword == NULL) { - - goto skip_keyword; - } - - ret = fscanf(initfile, "%9999s", scan_buf); - - if (ret == 0 || ret == EOF || 0 != ut_strcmp(scan_buf, keyword)) { - if (print_not_err) { - - return(DB_ERROR); - } - - printf("Error in InnoDB booting: keyword %s not found\n", - keyword); - printf("from the initfile!\n"); - - return(DB_ERROR); - } -skip_keyword: - if (num_val == NULL && str_buf == NULL) { - - return(DB_SUCCESS); - } - - ret = fscanf(initfile, "%9999s", scan_buf); - - if (ret == EOF || ret == 0) { - if (print_not_err) { - - return(DB_ERROR); - } - - printf( - "Error in InnoDB booting: could not read first value after %s\n", - keyword); - printf("from the initfile!\n"); - - return(DB_ERROR); - } - - if (str_buf) { - ut_memcpy(str_buf, scan_buf, 10000); - - printf("init keyword %s value %s read\n", keyword, str_buf); - - if (!num_val) { - return(DB_SUCCESS); - } - - ret = fscanf(initfile, "%9999s", scan_buf); - - if (ret == EOF || ret == 0) { - - if (print_not_err) { - - return(DB_ERROR); - } - - printf( - "Error in InnoDB booting: could not read second value after %s\n", - keyword); - printf("from the initfile!\n"); - - return(DB_ERROR); - } - } - - if (ut_strlen(scan_buf) > 9) { - - if (print_not_err) { - - return(DB_ERROR); - } - - printf( - "Error in InnoDB booting: numerical value too big after %s\n", - keyword); - printf("in the initfile!\n"); - - return(DB_ERROR); - } - - *num_val = (ulint)atoi(scan_buf); - - if (*num_val >= 1000000000) { - - if (print_not_err) { - - return(DB_ERROR); - } - - printf( - "Error in InnoDB booting: numerical value too big after %s\n", - keyword); - printf("in the initfile!\n"); - - return(DB_ERROR); - } - - printf("init keyword %s value %lu read\n", keyword, *num_val); - - return(DB_SUCCESS); -} - -/************************************************************************* -Reads keywords and values from an initfile. */ - -ulint -srv_read_initfile( -/*==============*/ - /* out: DB_SUCCESS or error code */ - FILE* initfile) /* in: file pointer */ -{ - char str_buf[10000]; - ulint n; - ulint i; - ulint ulint_val; - ulint val1; - ulint val2; - ulint err; - - err = srv_read_init_val(initfile, "INNOBASE_DATA_HOME_DIR", - str_buf, NULL, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_data_home = ut_malloc(ut_strlen(str_buf) + 1); - ut_memcpy(srv_data_home, str_buf, ut_strlen(str_buf) + 1); - - err = srv_read_init_val(initfile,"TABLESPACE_NUMBER_OF_DATA_FILES", - NULL, &n, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_n_data_files = n; - - srv_data_file_names = ut_malloc(n * sizeof(char*)); - srv_data_file_sizes = ut_malloc(n * sizeof(ulint)); - - for (i = 0; i < n; i++) { - err = srv_read_init_val(initfile, - "DATA_FILE_PATH_AND_SIZE_MB", - str_buf, &ulint_val, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_data_file_names[i] = ut_malloc(ut_strlen(str_buf) + 1); - ut_memcpy(srv_data_file_names[i], str_buf, - ut_strlen(str_buf) + 1); - srv_data_file_sizes[i] = ulint_val - * ((1024 * 1024) / UNIV_PAGE_SIZE); - } - - err = srv_read_init_val(initfile, - "NUMBER_OF_MIRRORED_LOG_GROUPS", NULL, - &srv_n_log_groups, FALSE); - if (err != DB_SUCCESS) return(err); - - err = srv_read_init_val(initfile, - "NUMBER_OF_LOG_FILES_IN_GROUP", NULL, - &srv_n_log_files, FALSE); - if (err != DB_SUCCESS) return(err); - - err = srv_read_init_val(initfile, "LOG_FILE_SIZE_KB", NULL, - &srv_log_file_size, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_log_file_size = srv_log_file_size / (UNIV_PAGE_SIZE / 1024); - - srv_log_group_home_dirs = ut_malloc(srv_n_log_files * sizeof(char*)); - - for (i = 0; i < srv_n_log_groups; i++) { - - err = srv_read_init_val(initfile, - "INNOBASE_LOG_GROUP_HOME_DIR", - str_buf, NULL, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_log_group_home_dirs[i] = ut_malloc(ut_strlen(str_buf) + 1); - ut_memcpy(srv_log_group_home_dirs[i], str_buf, - ut_strlen(str_buf) + 1); - } - - err = srv_read_init_val(initfile, "INNOBASE_LOG_ARCH_DIR", - str_buf, NULL, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_arch_dir = ut_malloc(ut_strlen(str_buf) + 1); - ut_memcpy(srv_arch_dir, str_buf, ut_strlen(str_buf) + 1); - - err = srv_read_init_val(initfile, "LOG_ARCHIVE_ON(1/0)", NULL, - &srv_log_archive_on, FALSE); - if (err != DB_SUCCESS) return(err); - - err = srv_read_init_val(initfile, "LOG_BUFFER_SIZE_KB", NULL, - &srv_log_buffer_size, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_log_buffer_size = srv_log_buffer_size / (UNIV_PAGE_SIZE / 1024); - - err = srv_read_init_val(initfile, "FLUSH_LOG_AT_TRX_COMMIT(1/0)", NULL, - &srv_flush_log_at_trx_commit, FALSE); - if (err != DB_SUCCESS) return(err); - - err = srv_read_init_val(initfile, "BUFFER_POOL_SIZE_MB", NULL, - &srv_pool_size, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_pool_size = srv_pool_size * ((1024 * 1024) / UNIV_PAGE_SIZE); - - err = srv_read_init_val(initfile, "ADDITIONAL_MEM_POOL_SIZE_MB", NULL, - &srv_mem_pool_size, FALSE); - if (err != DB_SUCCESS) return(err); - - srv_mem_pool_size = srv_mem_pool_size * 1024 * 1024; - - srv_lock_table_size = 20 * srv_pool_size; - - err = srv_read_init_val(initfile, "NUMBER_OF_FILE_IO_THREADS", NULL, - &srv_n_file_io_threads, FALSE); - if (err != DB_SUCCESS) return(err); - - err = srv_read_init_val(initfile, "SRV_RECOVER_FROM_BACKUP", - NULL, NULL, TRUE); - if (err == DB_SUCCESS) { - srv_archive_recovery = TRUE; - srv_archive_recovery_limit_lsn = ut_dulint_max; - - err = srv_read_init_val(initfile, NULL, NULL, &val1, TRUE); - err = srv_read_init_val(initfile, NULL, NULL, &val2, TRUE); - - if (err == DB_SUCCESS) { - srv_archive_recovery_limit_lsn = - ut_dulint_create(val1, val2); - } - } - - /* err = srv_read_init_val(initfile, - "SYNC_NUMBER_OF_SPIN_WAIT_ROUNDS", NULL, - &srv_n_spin_wait_rounds); - - err = srv_read_init_val(initfile, "SYNC_SPIN_WAIT_DELAY", NULL, - &srv_spin_wait_delay); */ - return(DB_SUCCESS); -} - -/************************************************************************* -Reads keywords and a values from an initfile. In case of an error, exits -from the process. */ - -void -srv_read_initfile( -/*==============*/ - FILE* initfile) /* in: file pointer */ -{ - char str_buf[10000]; - ulint ulint_val; - - srv_read_init_val(initfile, FALSE, "SRV_ENDPOINT_NAME", str_buf, - &ulint_val); - ut_a(ut_strlen(str_buf) < COM_MAX_ADDR_LEN); - - ut_memcpy(srv_endpoint_name, str_buf, COM_MAX_ADDR_LEN); - - srv_read_init_val(initfile, TRUE, "SRV_N_COM_THREADS", str_buf, - &srv_n_com_threads); - - srv_read_init_val(initfile, TRUE, "SRV_N_WORKER_THREADS", str_buf, - &srv_n_worker_threads); - - srv_read_init_val(initfile, TRUE, "SYNC_N_SPIN_WAIT_ROUNDS", str_buf, - &srv_n_spin_wait_rounds); - - srv_read_init_val(initfile, TRUE, "SYNC_SPIN_WAIT_DELAY", str_buf, - &srv_spin_wait_delay); - - srv_read_init_val(initfile, TRUE, "THREAD_PRIORITY_BOOST", str_buf, - &srv_priority_boost); - - srv_read_init_val(initfile, TRUE, "N_SPACES", str_buf, &srv_n_spaces); - srv_read_init_val(initfile, TRUE, "N_FILES", str_buf, &srv_n_files); - srv_read_init_val(initfile, TRUE, "FILE_SIZE", str_buf, - &srv_file_size); - - srv_read_init_val(initfile, TRUE, "N_LOG_GROUPS", str_buf, - &srv_n_log_groups); - srv_read_init_val(initfile, TRUE, "N_LOG_FILES", str_buf, - &srv_n_log_files); - srv_read_init_val(initfile, TRUE, "LOG_FILE_SIZE", str_buf, - &srv_log_file_size); - srv_read_init_val(initfile, TRUE, "LOG_ARCHIVE_ON", str_buf, - &srv_log_archive_on); - srv_read_init_val(initfile, TRUE, "LOG_BUFFER_SIZE", str_buf, - &srv_log_buffer_size); - srv_read_init_val(initfile, TRUE, "FLUSH_LOG_AT_TRX_COMMIT", str_buf, - &srv_flush_log_at_trx_commit); - - - srv_read_init_val(initfile, TRUE, "POOL_SIZE", str_buf, - &srv_pool_size); - srv_read_init_val(initfile, TRUE, "MEM_POOL_SIZE", str_buf, - &srv_mem_pool_size); - srv_read_init_val(initfile, TRUE, "LOCK_TABLE_SIZE", str_buf, - &srv_lock_table_size); - - srv_read_init_val(initfile, TRUE, "SIM_DISK_WAIT_PCT", str_buf, - &srv_sim_disk_wait_pct); - - srv_read_init_val(initfile, TRUE, "SIM_DISK_WAIT_LEN", str_buf, - &srv_sim_disk_wait_len); - - srv_read_init_val(initfile, TRUE, "SIM_DISK_WAIT_BY_YIELD", str_buf, - &srv_sim_disk_wait_by_yield); - - srv_read_init_val(initfile, TRUE, "SIM_DISK_WAIT_BY_WAIT", str_buf, - &srv_sim_disk_wait_by_wait); - - srv_read_init_val(initfile, TRUE, "MEASURE_CONTENTION", str_buf, - &srv_measure_contention); - - srv_read_init_val(initfile, TRUE, "MEASURE_BY_SPIN", str_buf, - &srv_measure_by_spin); - - - srv_read_init_val(initfile, TRUE, "PRINT_THREAD_RELEASES", str_buf, - &srv_print_thread_releases); - - srv_read_init_val(initfile, TRUE, "PRINT_LOCK_WAITS", str_buf, - &srv_print_lock_waits); - if (srv_print_lock_waits) { - lock_print_waits = TRUE; - } - - srv_read_init_val(initfile, TRUE, "PRINT_BUF_IO", str_buf, - &srv_print_buf_io); - if (srv_print_buf_io) { - buf_debug_prints = TRUE; - } - - srv_read_init_val(initfile, TRUE, "PRINT_LOG_IO", str_buf, - &srv_print_log_io); - if (srv_print_log_io) { - log_debug_writes = TRUE; - } - - srv_read_init_val(initfile, TRUE, "PRINT_PARSED_SQL", str_buf, - &srv_print_parsed_sql); - if (srv_print_parsed_sql) { - pars_print_lexed = TRUE; - } - - srv_read_init_val(initfile, TRUE, "PRINT_LATCH_WAITS", str_buf, - &srv_print_latch_waits); - - srv_read_init_val(initfile, TRUE, "TEST_EXTRA_MUTEXES", str_buf, - &srv_test_extra_mutexes); - srv_read_init_val(initfile, TRUE, "TEST_NOCACHE", str_buf, - &srv_test_nocache); - srv_read_init_val(initfile, TRUE, "TEST_CACHE_EVICT", str_buf, - &srv_test_cache_evict); - - srv_read_init_val(initfile, TRUE, "TEST_SYNC", str_buf, - &srv_test_sync); - srv_read_init_val(initfile, TRUE, "TEST_N_THREADS", str_buf, - &srv_test_n_threads); - srv_read_init_val(initfile, TRUE, "TEST_N_LOOPS", str_buf, - &srv_test_n_loops); - srv_read_init_val(initfile, TRUE, "TEST_N_FREE_RNDS", str_buf, - &srv_test_n_free_rnds); - srv_read_init_val(initfile, TRUE, "TEST_N_RESERVED_RNDS", str_buf, - &srv_test_n_reserved_rnds); - srv_read_init_val(initfile, TRUE, "TEST_N_MUTEXES", str_buf, - &srv_test_n_mutexes); - srv_read_init_val(initfile, TRUE, "TEST_ARRAY_SIZE", str_buf, - &srv_test_array_size); -} -#endif /************************************************************************* Initializes the server. */ diff --git a/innobase/srv/srv0start.c b/innobase/srv/srv0start.c index e6fdc95fad0..e671e95fad3 100644 --- a/innobase/srv/srv0start.c +++ b/innobase/srv/srv0start.c @@ -447,9 +447,9 @@ io_handler_thread( } #ifdef __WIN__ -#define SRV_PATH_SEPARATOR "\\" +#define SRV_PATH_SEPARATOR '\\' #else -#define SRV_PATH_SEPARATOR "/" +#define SRV_PATH_SEPARATOR '/' #endif /************************************************************************* @@ -477,31 +477,26 @@ srv_normalize_path_for_win( Adds a slash or a backslash to the end of a string if it is missing and the string is not empty. */ +static char* srv_add_path_separator_if_needed( /*=============================*/ - /* out, own: string which has the separator if the + /* out: string which has the separator if the string is not empty */ char* str) /* in: null-terminated character string */ { char* out_str; + ulint len = ut_strlen(str); - if (ut_strlen(str) == 0) { + if (len == 0 || str[len - 1] == SRV_PATH_SEPARATOR) { return(str); } - if (str[ut_strlen(str) - 1] == SRV_PATH_SEPARATOR[0]) { - out_str = ut_malloc(ut_strlen(str) + 1); - - sprintf(out_str, "%s", str); - - return(out_str); - } - - out_str = ut_malloc(ut_strlen(str) + 2); - - sprintf(out_str, "%s%s", str, SRV_PATH_SEPARATOR); + out_str = ut_malloc(len + 2); + memcpy(out_str, str, len); + out_str[len] = SRV_PATH_SEPARATOR; + out_str[len + 1] = 0; return(out_str); } diff --git a/innobase/srv/ts/makefile b/innobase/srv/ts/makefile deleted file mode 100644 index 0b743e37a20..00000000000 --- a/innobase/srv/ts/makefile +++ /dev/null @@ -1,15 +0,0 @@ - - - -include ..\..\makefile.i - -tssrv: ..\srv.lib tssrv.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\srv.lib ..\..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\btr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tssrv.c $(LFL) - - - - - - - - diff --git a/innobase/srv/ts/tsdbc.c b/innobase/srv/ts/tsdbc.c deleted file mode 100644 index 83ba081959d..00000000000 --- a/innobase/srv/ts/tsdbc.c +++ /dev/null @@ -1,118 +0,0 @@ -/************************************************************************ -Database client test program - -(c) 1995 Innobase Oy - -Created 10/10/1995 Heikki Tuuri -*************************************************************************/ - -#include "com0com.h" -#include "com0shm.h" -#include "ut0ut.h" -#include "mem0mem.h" -#include "os0thread.h" -#include "sync0ipm.h" -#include "sync0sync.h" - -byte buf[10000]; -char addr[150]; - -void -test1(void) -/*=======*/ -{ - com_endpoint_t* ep; - ulint ret; - ulint size; - ulint len; - ulint addr_len; - ulint i, j; - ulint tm, oldtm; - - - oldtm = ut_clock(); - - for (i = 0; i < 10000; i++) { - - ut_delay(100); - } - - for (j = 0; j < i / 10; j++) { - - ut_delay(200); - } - - tm = ut_clock(); - printf("Wall clock time for test without server %ld milliseconds\n", - tm - oldtm); - printf("%lu rounds\n", i); - - ep = com_endpoint_create(COM_SHM); - - ut_a(ep); - - size = 8192; - - ret = com_endpoint_set_option(ep, COM_OPT_MAX_DGRAM_SIZE, - (byte*)&size, 0); - - ut_a(ret == 0); - - ret = com_bind(ep, "CLI", 3); - - ut_a(ret == 0); - - printf("Client endpoint created!\n"); - - oldtm = ut_clock(); - - for (i = 0; i < 50000; i++) { - - ret = com_sendto(ep, (byte*)"Hello from client!\n", 18, "ibsrv", 5); - - ut_a(ret == 0); - - ret = com_recvfrom(ep, buf, 10000, &len, addr, 150, &addr_len); - - ut_a(ret == 0); - - buf[len] = '\0'; - addr[addr_len] = '\0'; -/* - printf( - "Message of len %lu\n%s \nreceived from address %s of len %lu\n", - len, buf, addr, addr_len); -*/ - } - - - tm = ut_clock(); - printf("Wall clock time for test %ld milliseconds\n", tm - oldtm); - printf("%lu message pairs\n", i); - - - printf("System calls in com_shm %lu ip_mutex %lu mutex %lu\n", - com_shm_system_call_count, - ip_mutex_system_call_count, - mutex_system_call_count); - - - ret = com_endpoint_free(ep); - - ut_ad(ret == 0); -} - -void -main(void) -/*======*/ -{ - - - - sync_init(); - mem_init(); - - test1(); - - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/srv/ts/tssrv.c b/innobase/srv/ts/tssrv.c deleted file mode 100644 index 92b98c4554e..00000000000 --- a/innobase/srv/ts/tssrv.c +++ /dev/null @@ -1,39 +0,0 @@ -/****************************************************** -Test for the database server - -(c) 1995 Innobase Oy - -Created 10/10/1995 Heikki Tuuri -*******************************************************/ - -#include "srv0srv.h" -#include "os0proc.h" -#include "ut0mem.h" - - -/*************************************************************************** -The main function of the server. */ - -void -main( -/*=*/ -#ifdef notdefined - - ulint argc, /* in: number of string arguments given on - the command line */ - char* argv[] -#endif -) /* in: array of character pointers giving - the arguments */ -{ -/* - if (argc != 2) { - printf("Error! Wrong number of command line arguments!\n"); - printf("Usage: ib <init-file-name>\n"); - os_process_exit(1); - } -*/ - srv_boot("init.ib"/*argv[1]*/); - - os_process_exit(0); -} diff --git a/innobase/sync/sync0rw.c b/innobase/sync/sync0rw.c index f552af1d1f0..e6da03c53fa 100644 --- a/innobase/sync/sync0rw.c +++ b/innobase/sync/sync0rw.c @@ -330,10 +330,10 @@ rw_lock_x_lock_low( lock->writer_count++; lock->pass = pass; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, pass, RW_LOCK_EX, file_name, line); - #endif +#endif lock->last_x_file_name = file_name; lock->last_x_line = line; @@ -346,10 +346,10 @@ rw_lock_x_lock_low( lock->pass = pass; lock->writer_is_wait_ex = TRUE; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, pass, RW_LOCK_WAIT_EX, file_name, line); - #endif +#endif return(RW_LOCK_WAIT_EX); } @@ -365,11 +365,11 @@ rw_lock_x_lock_low( lock->pass = pass; lock->writer_is_wait_ex = FALSE; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_remove_debug_info(lock, pass, RW_LOCK_WAIT_EX); rw_lock_add_debug_info(lock, pass, RW_LOCK_EX, file_name, line); - #endif +#endif lock->last_x_file_name = file_name; lock->last_x_line = line; @@ -388,10 +388,10 @@ rw_lock_x_lock_low( lock->writer_count++; - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG rw_lock_add_debug_info(lock, pass, RW_LOCK_EX, file_name, line); - #endif +#endif lock->last_x_file_name = file_name; lock->last_x_line = line; diff --git a/innobase/sync/sync0sync.c b/innobase/sync/sync0sync.c index eb13c59baf4..d5a6fff47bf 100644 --- a/innobase/sync/sync0sync.c +++ b/innobase/sync/sync0sync.c @@ -314,9 +314,9 @@ mutex_enter_nowait( if (!mutex_test_and_set(mutex)) { - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG mutex_set_debug_info(mutex, file_name, line); - #endif +#endif mutex->file_name = file_name; mutex->line = line; @@ -415,9 +415,9 @@ spin_loop: if (mutex_test_and_set(mutex) == 0) { /* Succeeded! */ - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG mutex_set_debug_info(mutex, file_name, line); - #endif +#endif mutex->file_name = file_name; mutex->line = line; @@ -462,9 +462,9 @@ spin_loop: sync_array_free_cell(sync_primary_wait_array, index); - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG mutex_set_debug_info(mutex, file_name, line); - #endif +#endif mutex->file_name = file_name; mutex->line = line; @@ -685,18 +685,18 @@ ibool sync_all_freed(void) /*================*/ { - #ifdef UNIV_SYNC_DEBUG +#ifdef UNIV_SYNC_DEBUG if (mutex_n_reserved() + rw_lock_n_locked() == 0) { return(TRUE); } else { return(FALSE); } - #else +#else ut_error; return(FALSE); - #endif +#endif } /********************************************************************** diff --git a/innobase/sync/ts/makefile b/innobase/sync/ts/makefile deleted file mode 100644 index 95011f51466..00000000000 --- a/innobase/sync/ts/makefile +++ /dev/null @@ -1,14 +0,0 @@ - - - -include ..\..\makefile.i - -tssync: ..\sync.lib tssync.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\sync.lib ..\..\mach.lib ..\..\ut.lib ..\..\mem.lib ..\..\os.lib tssync.c $(LFL) - - - - - - - diff --git a/innobase/sync/ts/tssync.c b/innobase/sync/ts/tssync.c deleted file mode 100644 index bf30a603284..00000000000 --- a/innobase/sync/ts/tssync.c +++ /dev/null @@ -1,1366 +0,0 @@ -/************************************************************************ -The test module for the syncronization primitives - -(c) 1995 Innobase Oy - -Created 9/9/1995 Heikki Tuuri -*************************************************************************/ - - -#include "../sync0sync.h" -#include "../sync0rw.h" -#include "../sync0arr.h" -#include "../sync0ipm.h" -#include "ut0ut.h" -#include "mem0mem.h" -#include "os0sync.h" -#include "os0thread.h" -#include "os0sync.h" - -mutex_t mutex; -mutex_t mutex1; -mutex_t mutex2; -mutex_t mutex3; -mutex_t mutex4; - -ip_mutex_t ip_mutex; - -ip_mutex_t ip_mutex1; -ip_mutex_t ip_mutex2; -ip_mutex_t ip_mutex3; -ip_mutex_t ip_mutex4; - -ip_mutex_hdl_t* iph; - -ip_mutex_hdl_t* iph1; -ip_mutex_hdl_t* iph2; -ip_mutex_hdl_t* iph3; -ip_mutex_hdl_t* iph4; - - -rw_lock_t rw1; -rw_lock_t rw2; -rw_lock_t rw3; -rw_lock_t rw4; - -rw_lock_t rw9; -rw_lock_t rw10; -mutex_t mutex9; - -os_mutex_t osm; - -ulint last_thr; -ulint switch_count; -ulint glob_count; -ulint glob_inc; -ulint rc; - -bool qprint = FALSE; - -/******************************************************************** -Start function for thread 1 in test1. */ -ulint -thread1(void* arg) -/*==============*/ -{ - ulint i, j; - void* arg2; - - arg2 = arg; - - printf("Thread1 started!\n"); - - mutex_enter(&mutex); - - printf("Thread1 owns now the mutex!\n"); - - j = 0; - - for (i = 1; i < 1000000; i++) { - j += i; - } - - printf("Thread1 releases now the mutex!\n"); - - mutex_exit(&mutex); - - return(j); -} - -/******************************************************************** -Start function for thread 2 in test1. */ -ulint -thread2(void* arg) -/*==============*/ -{ - ulint i, j; - void* arg2; - - arg2 = arg; - - printf("Thread2 started!\n"); - - mutex_enter(&mutex); - - printf("Thread2 owns now the mutex!\n"); - - j = 0; - - for (i = 1; i < 1000000; i++) { - j += i; - } - - printf("Thread2 releases now the mutex!\n"); - - mutex_exit(&mutex); - - return(j); -} - -/******************************************************************** -Start function for the competing threads in test2. The function tests -the behavior lock-coupling through 4 mutexes. */ - -ulint -thread_n(volatile void* arg) -/*========================*/ -{ - ulint i, j, k, n; - - n = *((ulint*)arg); - - printf("Thread %ld started!\n", n); - - for (k = 0; k < 2000 * UNIV_DBC; k++) { - - mutex_enter(&mutex1); - - if (last_thr != n) { - switch_count++; - last_thr = n; - } - - j = 0; - - for (i = 1; i < 400; i++) { - j += i; - } - - mutex_enter(&mutex2); - - mutex_exit(&mutex1); - - for (i = 1; i < 400; i++) { - j += i; - } - mutex_enter(&mutex3); - - mutex_exit(&mutex2); - - for (i = 1; i < 400; i++) { - j += i; - } - mutex_enter(&mutex4); - - mutex_exit(&mutex3); - - for (i = 1; i < 400; i++) { - j += i; - } - - mutex_exit(&mutex4); - } - - printf("Thread %ld exits!\n", n); - - return(j); -} - -/******************************************************************** -Start function for mutex exclusion checking in test3. */ - -ulint -thread_x(void* arg) -/*===============*/ -{ - ulint k; - void* arg2; - - arg2 = arg; - - printf("Starting thread!\n"); - - for (k = 0; k < 200000 * UNIV_DBC; k++) { - - mutex_enter(&mutex); - - glob_count += glob_inc; - - mutex_exit(&mutex); - - } - - printf("Exiting thread!\n"); - - return(0); -} - - - -void -test1(void) -/*=======*/ -{ - os_thread_t thr1, thr2; - os_thread_id_t id1, id2; - ulint i, j; - ulint tm, oldtm; - ulint* lp; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 1. Test of mutexes.\n"); - - - printf("Main thread %ld starts!\n", - os_thread_get_curr_id()); - - osm = os_mutex_create(NULL); - - os_mutex_enter(osm); - os_mutex_exit(osm); - - os_mutex_free(osm); - - - mutex_create(&mutex); - - lp = &j; - - oldtm = ut_clock(); - - for (i = 0; i < 1000000; i++) { - id1 = os_thread_get_curr_id(); - } - - tm = ut_clock(); - printf("Wall clock time for %ld thread_get_id %ld milliseconds\n", - i, tm - oldtm); - - - oldtm = ut_clock(); - - for (i = 0; i < 100000 * UNIV_DBC; i++) { - - mutex_enter(&mutex); - mutex_exit(&mutex); - } - - tm = ut_clock(); - printf("Wall clock time for %ld mutex lock-unlock %ld milliseconds\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 1000000; i++) { - - mutex_fence(); - } - - tm = ut_clock(); - printf("Wall clock time for %ld fences %ld milliseconds\n", - i, tm - oldtm); - - mutex_enter(&mutex); - - mutex_list_print_info(); - - ut_ad(1 == mutex_n_reserved()); - ut_ad(FALSE == sync_all_freed()); - - thr1 = os_thread_create(thread1, - NULL, - &id1); - - printf("Thread1 created, id %ld \n", id1); - - thr2 = os_thread_create(thread2, - NULL, - &id2); - - printf("Thread2 created, id %ld \n", id2); - - - j = 0; - - for (i = 1; i < 20000000; i++) { - j += i; - } - - sync_print(); - - sync_array_validate(sync_primary_wait_array); - - printf("Main thread releases now mutex!\n"); - - mutex_exit(&mutex); - - os_thread_wait(thr2); - - os_thread_wait(thr1); -} - -/****************************************************************** -Test function for possible convoy problem. */ - -void -test2(void) -/*=======*/ -{ - os_thread_t thr1, thr2, thr3, thr4, thr5; - os_thread_id_t id1, id2, id3, id4, id5; - ulint tm, oldtm; - ulint n1, n2, n3, n4, n5; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 2. Test of possible convoy problem.\n"); - - printf("System call count %lu\n", mutex_system_call_count); - - mutex_create(&mutex1); - mutex_create(&mutex2); - mutex_create(&mutex3); - mutex_create(&mutex4); - - switch_count = 0; - - oldtm = ut_clock(); - - n1 = 1; - - thr1 = os_thread_create(thread_n, - &n1, - &id1); - - os_thread_wait(thr1); - - - tm = ut_clock(); - printf("Wall clock time for single thread %ld milliseconds\n", - tm - oldtm); - printf("System call count %lu\n", mutex_system_call_count); - - switch_count = 0; - - oldtm = ut_clock(); - - n1 = 1; - thr1 = os_thread_create(thread_n, - &n1, - &id1); - n2 = 2; - thr2 = os_thread_create(thread_n, - &n2, - &id2); - n3 = 3; - thr3 = os_thread_create(thread_n, - &n3, - &id3); - n4 = 4; - thr4 = os_thread_create(thread_n, - &n4, - &id4); - n5 = 5; - thr5 = os_thread_create(thread_n, - &n5, - &id5); - - - os_thread_wait(thr1); - os_thread_wait(thr2); - os_thread_wait(thr3); - os_thread_wait(thr4); - os_thread_wait(thr5); - - - tm = ut_clock(); - printf("Wall clock time for 5 threads %ld milliseconds\n", - tm - oldtm); - printf("%ld thread switches occurred\n", switch_count); - - printf("If this is not 5 x single thread time, possibly convoy!\n"); - - printf("System call count %lu\n", mutex_system_call_count); -} - -/****************************************************************** -Test function for possible exclusion failure. */ - -void -test3(void) -/*=======*/ -{ - os_thread_t thr1, thr2; - os_thread_id_t id1, id2; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 3. Test of possible exclusion failure.\n"); - - glob_count = 0; - glob_inc = 1; - - thr1 = os_thread_create(thread_x, - NULL, - &id1); - thr2 = os_thread_create(thread_x, - NULL, - &id2); - - os_thread_wait(thr2); - os_thread_wait(thr1); - - ut_a(glob_count == 400000 * UNIV_DBC); -} - -/****************************************************************** -Test function for measuring the spin wait loop cycle time. */ - -void -test4(void) -/*=======*/ -{ -volatile ulint* ptr; - ulint i, tm, oldtm; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 4. Test of spin wait loop cycle time.\n"); - printf("Use this time to set the SYNC_SPIN_ROUNDS constant.\n"); - - - glob_inc = 1; - - ptr = &glob_inc; - - oldtm = ut_clock(); - - i = 0; - - while ((*ptr != 0) && (i < 10000000)) { - i++; - } - - tm = ut_clock(); - printf("Wall clock time for %ld cycles %ld milliseconds\n", - i, tm - oldtm); -} - -/******************************************************************** -Start function for s-lock thread in test5. */ -ulint -thread_srw(void* arg) -/*==============*/ -{ - ulint i, j; - void* arg2; - - arg2 = arg; - - printf("Thread_srw started!\n"); - - rw_lock_s_lock(&rw1); - - printf("Thread_srw has now s-lock!\n"); - - j = 0; - - for (i = 1; i < 1000000; i++) { - j += i; - } - - printf("Thread_srw releases now the s-lock!\n"); - - rw_lock_s_unlock(&rw1); - - return(j); -} - -/******************************************************************** -Start function for x-lock thread in test5. */ -ulint -thread_xrw(void* arg) -/*==============*/ -{ - ulint i, j; - void* arg2; - - arg2 = arg; - - printf("Thread_xrw started!\n"); - - rw_lock_x_lock(&rw1); - - printf("Thread_xrw has now x-lock!\n"); - - j = 0; - - for (i = 1; i < 1000000; i++) { - j += i; - } - - printf("Thread_xrw releases now the x-lock!\n"); - - rw_lock_x_unlock(&rw1); - - return(j); -} - - -void -test5(void) -/*=======*/ -{ - os_thread_t thr1, thr2; - os_thread_id_t id1, id2; - ulint i, j; - ulint tm, oldtm; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 5. Test of read-write locks.\n"); - - - printf("Main thread %ld starts!\n", - os_thread_get_curr_id()); - - - rw_lock_create(&rw1); - - oldtm = ut_clock(); - - - for (i = 0; i < 10000 * UNIV_DBC * UNIV_DBC; i++) { - - rw_lock_s_lock(&rw1); - - rw_lock_s_unlock(&rw1); - - } - - tm = ut_clock(); - printf("Wall clock time for %ld rw s-lock-unlock %ld milliseconds\n", - i, tm - oldtm); - - - oldtm = ut_clock(); - - - for (i = 0; i < 10000 * UNIV_DBC * UNIV_DBC; i++) { - - mutex_enter(&mutex); - rc++; - mutex_exit(&mutex); - - mutex_enter(&mutex); - rc--; - mutex_exit(&mutex); - } - - tm = ut_clock(); - printf("Wall clock time for %ld rw test %ld milliseconds\n", - i, tm - oldtm); - - - - oldtm = ut_clock(); - - for (i = 0; i < 10000 * UNIV_DBC * UNIV_DBC; i++) { - - rw_lock_x_lock(&rw1); - rw_lock_x_unlock(&rw1); - - } - - tm = ut_clock(); - printf("Wall clock time for %ld rw x-lock-unlock %ld milliseconds\n", - i, tm - oldtm); - - - /* Test recursive x-locking */ - for (i = 0; i < 10000; i++) { - rw_lock_x_lock(&rw1); - } - - for (i = 0; i < 10000; i++) { - - rw_lock_x_unlock(&rw1); - } - - /* Test recursive s-locking */ - for (i = 0; i < 10000; i++) { - - rw_lock_s_lock(&rw1); - } - - for (i = 0; i < 10000; i++) { - - rw_lock_s_unlock(&rw1); - } - - rw_lock_s_lock(&rw1); - - ut_ad(1 == rw_lock_n_locked()); - - mem_print_info(); - - rw_lock_list_print_info(); - - thr2 = os_thread_create(thread_xrw, - NULL, - &id2); - - printf("Thread_xrw created, id %ld \n", id2); - - - thr1 = os_thread_create(thread_srw, - NULL, - &id1); - - printf("Thread_srw created, id %ld \n", id1); - - j = 0; - - for (i = 1; i < 10000000; i++) { - j += i; - } - - rw_lock_list_print_info(); - - sync_array_validate(sync_primary_wait_array); - - printf("Main thread releases now rw-lock!\n"); - - rw_lock_s_unlock(&rw1); - - os_thread_wait(thr2); - - os_thread_wait(thr1); - - sync_array_print_info(sync_primary_wait_array); -} - -/******************************************************************** -Start function for the competing s-threads in test6. The function tests -the behavior lock-coupling through 4 rw-locks. */ - -ulint -thread_qs(volatile void* arg) -/*========================*/ -{ - ulint i, j, k, n; - - arg = arg; - - n = os_thread_get_curr_id(); - - printf("S-Thread %ld started, thread id %lu\n", n, - os_thread_get_curr_id()); - - for (k = 0; k < 1000 * UNIV_DBC; k++) { - - if (qprint) - printf("S-Thread %ld starts round %ld!\n", n, k); - - rw_lock_s_lock(&rw1); - - if (qprint) - printf("S-Thread %ld got lock 1 on round %ld!\n", n, k); - - - if (last_thr != n) { - switch_count++; - last_thr = n; - } - - j = 0; - - for (i = 1; i < 400; i++) { - j += i; - } - - rw_lock_s_lock(&rw2); - - if (qprint) - printf("S-Thread %ld got lock 2 on round %ld!\n", n, k); - - - rw_lock_s_unlock(&rw1); - - if (qprint) - printf("S-Thread %ld released lock 1 on round %ld!\n", n, k); - - - for (i = 1; i < 400; i++) { - j += i; - } - rw_lock_s_lock(&rw3); - - if (qprint) - printf("S-Thread %ld got lock 3 on round %ld!\n", n, k); - - - rw_lock_s_unlock(&rw2); - if (qprint) - printf("S-Thread %ld released lock 2 on round %ld!\n", n, k); - - - for (i = 1; i < 400; i++) { - j += i; - } - rw_lock_s_lock(&rw4); - - if (qprint) - printf("S-Thread %ld got lock 4 on round %ld!\n", n, k); - - - rw_lock_s_unlock(&rw3); - if (qprint) - printf("S-Thread %ld released lock 3 on round %ld!\n", n, k); - - - for (i = 1; i < 400; i++) { - j += i; - } - - rw_lock_s_unlock(&rw4); - if (qprint) - printf("S-Thread %ld released lock 4 on round %ld!\n", n, k); - - } - - printf("S-Thread %ld exits!\n", n); - - return(j); -} - -/******************************************************************** -Start function for the competing x-threads in test6. The function tests -the behavior lock-coupling through 4 rw-locks. */ - -ulint -thread_qx(volatile void* arg) -/*========================*/ -{ - ulint i, j, k, n; - - arg = arg; - - n = os_thread_get_curr_id(); - - printf("X-Thread %ld started, thread id %lu\n", n, - os_thread_get_curr_id()); - - for (k = 0; k < 1000 * UNIV_DBC; k++) { - - if (qprint) - printf("X-Thread %ld round %ld!\n", n, k); - - - rw_lock_x_lock(&rw1); - if (qprint) - printf("X-Thread %ld got lock 1 on round %ld!\n", n, k); - - - if (last_thr != n) { - switch_count++; - last_thr = n; - } - - j = 0; - - for (i = 1; i < 400; i++) { - j += i; - } - - rw_lock_x_lock(&rw2); - if (qprint) - printf("X-Thread %ld got lock 2 on round %ld!\n", n, k); - - - rw_lock_x_unlock(&rw1); - if (qprint) - printf("X-Thread %ld released lock 1 on round %ld!\n", n, k); - - - for (i = 1; i < 400; i++) { - j += i; - } - rw_lock_x_lock(&rw3); - if (qprint) - printf("X-Thread %ld got lock 3 on round %ld!\n", n, k); - - - rw_lock_x_unlock(&rw2); - if (qprint) - printf("X-Thread %ld released lock 2 on round %ld!\n", n, k); - - - for (i = 1; i < 400; i++) { - j += i; - } - rw_lock_x_lock(&rw4); - if (qprint) - printf("X-Thread %ld got lock 4 on round %ld!\n", n, k); - - rw_lock_x_unlock(&rw3); - if (qprint) - printf("X-Thread %ld released lock 3 on round %ld!\n", n, k); - - - for (i = 1; i < 400; i++) { - j += i; - } - - rw_lock_x_unlock(&rw4); - if (qprint) - printf("X-Thread %ld released lock 4 on round %ld!\n", n, k); - - } - - printf("X-Thread %ld exits!\n", n); - - return(j); -} - -/****************************************************************** -Test function for possible queuing problems with rw-locks. */ - -void -test6(void) -/*=======*/ -{ - os_thread_t thr1, thr2, thr3, thr4, thr5; - os_thread_id_t id1, id2, id3, id4, id5; - ulint tm, oldtm; - ulint n1, n2, n3, n4, n5; - - printf("-------------------------------------------\n"); - printf( - "SYNC-TEST 6. Test of possible queuing problems with rw-locks.\n"); -/* - sync_array_print_info(sync_primary_wait_array); -*/ - - rw_lock_create(&rw2); - rw_lock_create(&rw3); - rw_lock_create(&rw4); - - switch_count = 0; - - - oldtm = ut_clock(); - - n1 = 1; - - thr1 = os_thread_create(thread_qs, - &n1, - &id1); - - os_thread_wait(thr1); - - - tm = ut_clock(); - printf("Wall clock time for single s-lock thread %ld milliseconds\n", - tm - oldtm); - - oldtm = ut_clock(); - - n1 = 1; - - thr1 = os_thread_create(thread_qx, - &n1, - &id1); - - os_thread_wait(thr1); - - - tm = ut_clock(); - printf("Wall clock time for single x-lock thread %ld milliseconds\n", - tm - oldtm); - - switch_count = 0; - - oldtm = ut_clock(); - - - n1 = 1; - thr1 = os_thread_create(thread_qx, - &n1, - &id1); - - n2 = 2; - thr2 = os_thread_create(thread_qs, - &n2, - &id2); - - n3 = 3; - thr3 = os_thread_create(thread_qx, - &n3, - &id3); - - - n4 = 4; - thr4 = os_thread_create(thread_qs, - &n4, - &id4); - - n5 = 5; - thr5 = os_thread_create(thread_qx, - &n5, - &id5); - - os_thread_wait(thr1); - - os_thread_wait(thr2); - - os_thread_wait(thr3); - - os_thread_wait(thr4); - - os_thread_wait(thr5); - - - tm = ut_clock(); - printf("Wall clock time for 5 threads %ld milliseconds\n", - tm - oldtm); - printf("at least %ld thread switches occurred\n", switch_count); - - printf( - "If this is not 2 x s-thread + 3 x x-thread time, possibly convoy!\n"); - - rw_lock_list_print_info(); - - sync_array_print_info(sync_primary_wait_array); - -} - -/******************************************************************** -Start function for thread in test7. */ -ulint -ip_thread(void* arg) -/*================*/ -{ - ulint i, j; - void* arg2; - ulint ret; - ulint tm, oldtm; - - arg2 = arg; - - printf("Thread started!\n"); - - oldtm = ut_clock(); - - ret = ip_mutex_enter(iph, 100000); - -/* ut_a(ret == SYNC_TIME_EXCEEDED); -*/ - tm = ut_clock(); - - printf("Wall clock time for wait failure %ld ms\n", tm - oldtm); - - ret = ip_mutex_enter(iph, SYNC_INFINITE_TIME); - - ut_a(ret == 0); - - printf("Thread owns now the ip mutex!\n"); - - j = 0; - - for (i = 1; i < 1000000; i++) { - j += i; - } - - printf("Thread releases now the ip mutex!\n"); - - ip_mutex_exit(iph); - - return(j); -} - -/********************************************************************* -Test for interprocess mutex. */ -void -test7(void) -/*=======*/ -{ - os_thread_t thr1; - os_thread_id_t id1; - ulint i, j; - ulint tm, oldtm; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 7. Test of ip mutex.\n"); - - - printf("Main thread %ld starts!\n", - os_thread_get_curr_id()); - - ip_mutex_create(&ip_mutex, "IPMUTEX", &iph); - - oldtm = ut_clock(); - - for (i = 0; i < 100000 * UNIV_DBC; i++) { - - ip_mutex_enter(iph, SYNC_INFINITE_TIME); - ip_mutex_exit(iph); - } - - tm = ut_clock(); - printf("Wall clock time for %ld ip mutex lock-unlock %ld ms\n", - i, tm - oldtm); - - - ip_mutex_enter(iph, SYNC_INFINITE_TIME); - - thr1 = os_thread_create(ip_thread, - NULL, - &id1); - - printf("Thread created, id %ld \n", id1); - - - j = 0; - - for (i = 1; i < 100000000; i++) { - j += i; - } - - printf("Main thread releases now ip mutex!\n"); - - ip_mutex_exit(iph); - - os_thread_wait(thr1); - - ip_mutex_free(iph); -} - -/******************************************************************** -Start function for the competing threads in test8. The function tests -the behavior lock-coupling through 4 ip mutexes. */ - -ulint -thread_ipn(volatile void* arg) -/*========================*/ -{ - ulint i, j, k, n; - - n = *((ulint*)arg); - - printf("Thread %ld started!\n", n); - - for (k = 0; k < 2000 * UNIV_DBC; k++) { - - ip_mutex_enter(iph1, SYNC_INFINITE_TIME); - - if (last_thr != n) { - switch_count++; - last_thr = n; - } - - j = 0; - - for (i = 1; i < 400; i++) { - j += i; - } - - ip_mutex_enter(iph2, SYNC_INFINITE_TIME); - - ip_mutex_exit(iph1); - - for (i = 1; i < 400; i++) { - j += i; - } - ip_mutex_enter(iph3, SYNC_INFINITE_TIME); - - ip_mutex_exit(iph2); - - for (i = 1; i < 400; i++) { - j += i; - } - ip_mutex_enter(iph4, SYNC_INFINITE_TIME); - - ip_mutex_exit(iph3); - - for (i = 1; i < 400; i++) { - j += i; - } - - ip_mutex_exit(iph4); - } - - printf("Thread %ld exits!\n", n); - - return(j); -} - -/****************************************************************** -Test function for ip mutex. */ - -void -test8(void) -/*=======*/ -{ - os_thread_t thr1, thr2, thr3, thr4, thr5; - os_thread_id_t id1, id2, id3, id4, id5; - ulint tm, oldtm; - ulint n1, n2, n3, n4, n5; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 8. Test for ip mutex.\n"); - - - ip_mutex_create(&ip_mutex1, "jhfhk", &iph1); - ip_mutex_create(&ip_mutex2, "jggfg", &iph2); - ip_mutex_create(&ip_mutex3, "hfdx", &iph3); - ip_mutex_create(&ip_mutex4, "kjghg", &iph4); - - switch_count = 0; - - oldtm = ut_clock(); - - n1 = 1; - - thr1 = os_thread_create(thread_ipn, - &n1, - &id1); - - os_thread_wait(thr1); - - - tm = ut_clock(); - printf("Wall clock time for single thread %lu milliseconds\n", - tm - oldtm); - - switch_count = 0; - - oldtm = ut_clock(); - - n1 = 1; - thr1 = os_thread_create(thread_ipn, - &n1, - &id1); - n2 = 2; - thr2 = os_thread_create(thread_ipn, - &n2, - &id2); - n3 = 3; - thr3 = os_thread_create(thread_ipn, - &n3, - &id3); - n4 = 4; - thr4 = os_thread_create(thread_ipn, - &n4, - &id4); - n5 = 5; - thr5 = os_thread_create(thread_ipn, - &n5, - &id5); - - os_thread_wait(thr1); - os_thread_wait(thr2); - os_thread_wait(thr3); - os_thread_wait(thr4); - os_thread_wait(thr5); - - - tm = ut_clock(); - printf("Wall clock time for 5 threads %ld milliseconds\n", - tm - oldtm); - printf("%ld thread switches occurred\n", switch_count); - - printf("If this is not 5 x single thread time, possibly convoy!\n"); - - ip_mutex_free(iph1); - ip_mutex_free(iph2); - ip_mutex_free(iph3); - ip_mutex_free(iph4); -} - - -/******************************************************************** -Start function for s-lock thread in test9. */ -ulint -thread_srw9(void* arg) -/*==================*/ -{ - void* arg2; - - arg2 = arg; - - printf("Thread_srw9 started!\n"); - - rw_lock_x_lock(&rw10); - - printf("Thread_srw9 has now x-lock on rw10, wait for mutex!\n"); - - mutex_enter(&mutex9); - - return(0); -} - -/******************************************************************** -Start function for x-lock thread in test9. */ -ulint -thread_xrw9(void* arg) -/*==================*/ -{ - void* arg2; - - arg2 = arg; - - printf("Thread_xrw started!\n"); - - mutex_enter(&mutex9); - printf("Thread_xrw9 has now mutex9, wait for rw9!\n"); - - rw_lock_x_lock(&rw9); - - return(0); -} - -void -test9(void) -/*=======*/ -{ - os_thread_t thr1, thr2; - os_thread_id_t id1, id2; - - printf("-------------------------------------------\n"); - printf("SYNC-TEST 9. Test of deadlock detection.\n"); - - - printf("Main thread %ld starts!\n", - os_thread_get_curr_id()); - - rw_lock_create(&rw9); - rw_lock_create(&rw10); - mutex_create(&mutex9); - - rw_lock_s_lock(&rw9); - printf("Main thread has now s-lock on rw9\n"); - - thr2 = os_thread_create(thread_xrw9, - NULL, - &id2); - - printf("Thread_xrw9 created, id %ld \n", id2); - - os_thread_sleep(1000000); - - thr1 = os_thread_create(thread_srw9, - NULL, - &id1); - - printf("Thread_srw9 created, id %ld \n", id1); - - os_thread_sleep(1000000); - - sync_array_print_info(sync_primary_wait_array); - - printf("Now we should have a deadlock of 3 threads:\n"); - - rw_lock_s_lock(&rw10); -} - -void -test10(void) -/*=======*/ -{ - printf("-------------------------------------------\n"); - printf("SYNC-TEST 10. Test of deadlock detection on self-deadlock.\n"); - - - printf("Main thread %ld starts!\n", - os_thread_get_curr_id()); - - mutex_create(&mutex9); - - printf("Now we should have a deadlock of this thread on mutex:\n"); - - mutex_enter(&mutex9); - mutex_enter(&mutex9); -} - -void -test11(void) -/*=======*/ -{ - printf("-------------------------------------------\n"); - printf("SYNC-TEST 11. Test of deadlock detection on self-deadlock.\n"); - - - printf("Main thread %ld starts!\n", - os_thread_get_curr_id()); - - rw_lock_create(&rw9); - - printf("Now we should have a deadlock of this thread on X-lock:\n"); - - rw_lock_x_lock(&rw9); - rw_lock_s_lock_gen(&rw9, 567); -} - - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - sync_init(); - mem_init(); - - oldtm = ut_clock(); - - test1(); - - test2(); - - test3(); - - test4(); - - test5(); - - test6(); - - test7(); - - test8(); - - /* This test SHOULD result in assert on deadlock! */ -/* test9();*/ - - /* This test SHOULD result in assert on deadlock! */ -/* test10();*/ - - /* This test SHOULD result in assert on deadlock! */ -/* test11();*/ - - ut_ad(0 == mutex_n_reserved()); - ut_ad(0 == rw_lock_n_locked()); - ut_ad(sync_all_freed()); - - - ut_ad(mem_all_freed()); - - sync_close(); - - tm = ut_clock(); - printf("Wall clock time for test %ld milliseconds\n", tm - oldtm); - printf("System call count %lu\n", mutex_system_call_count); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} - - diff --git a/innobase/thr/ts/makefile b/innobase/thr/ts/makefile deleted file mode 100644 index 517f50d197a..00000000000 --- a/innobase/thr/ts/makefile +++ /dev/null @@ -1,14 +0,0 @@ - - - -include ..\..\makefile.i - -tsthr: ..\thr.lib tsthr.c makefile - $(CCOM) $(CFL) -I.. -I..\.. ..\thr.lib ..\..\ha.lib ..\..\sync.lib ..\..\ut.lib ..\..\mem.lib ..\..\os.lib tsthr.c $(LFL) - - - - - - - diff --git a/innobase/thr/ts/tsthr.c b/innobase/thr/ts/tsthr.c deleted file mode 100644 index af5aaa54522..00000000000 --- a/innobase/thr/ts/tsthr.c +++ /dev/null @@ -1,131 +0,0 @@ -/************************************************************************ -The test module for the thread management of Innobase - -(c) 1995 Innobase Oy - -Created 10/5/1995 Heikki Tuuri -*************************************************************************/ - -#include "../thr0loc.h" -#include "sync0sync.h" -#include "mem0mem.h" -#include "os0thread.h" -#include "os0sync.h" -#include "ut0ut.h" - -ulint val = 500; -os_event_t event; - -/****************************************************************** -Thread start function in test1. */ - -ulint -thread1( -/*====*/ - void* arg) -{ - ulint n; - - thr_local_create(); - - n = *((ulint*)arg); - - printf("Thread %lu starts\n", n); - - thr_local_set_slot_no(os_thread_get_curr_id(), n); - - ut_a(n == thr_local_get_slot_no(os_thread_get_curr_id())); - - os_event_wait(event); - - thr_local_free(); - - os_thread_exit(0); - - return(0); -} - -/****************************************************************** -Test function for local storage. */ - -void -test1(void) -/*=======*/ -{ - os_thread_t thr1, thr2, thr3, thr4, thr5; - os_thread_id_t id1, id2, id3, id4, id5; - ulint tm, oldtm; - ulint n1, n2, n3, n4, n5; - - printf("-------------------------------------------\n"); - printf("THR-TEST 1. Test of local storage\n"); - - event = os_event_create(NULL); - - oldtm = ut_clock(); - - n1 = 1; - thr1 = os_thread_create(thread1, - &n1, - &id1); - n2 = 2; - thr2 = os_thread_create(thread1, - &n2, - &id2); - n3 = 3; - thr3 = os_thread_create(thread1, - &n3, - &id3); - n4 = 4; - thr4 = os_thread_create(thread1, - &n4, - &id4); - n5 = 5; - thr5 = os_thread_create(thread1, - &n5, - &id5); - - os_thread_sleep(500000); - - ut_a(n1 == thr_local_get_slot_no(id1)); - ut_a(n2 == thr_local_get_slot_no(id2)); - ut_a(n3 == thr_local_get_slot_no(id3)); - ut_a(n4 == thr_local_get_slot_no(id4)); - ut_a(n5 == thr_local_get_slot_no(id5)); - - os_event_set(event); - - os_thread_wait(thr1); - os_thread_wait(thr2); - os_thread_wait(thr3); - os_thread_wait(thr4); - os_thread_wait(thr5); - - tm = ut_clock(); - printf("Wall clock time for 5 threads %ld milliseconds\n", - tm - oldtm); -} - -/************************************************************************ -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - - sync_init(); - mem_init(); - thr_local_init(); - - oldtm = ut_clock(); - - test1(); - - thr_local_close(); - - tm = ut_clock(); - printf("Wall clock time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/trx/trx0trx.c b/innobase/trx/trx0trx.c index 3926cfa03c5..47927976851 100644 --- a/innobase/trx/trx0trx.c +++ b/innobase/trx/trx0trx.c @@ -1147,8 +1147,6 @@ trx_sig_send( ut_a(0); - /* sess_raise_error_low(trx, 0, 0, NULL, NULL, NULL, NULL, - "Incompatible signal"); */ return(FALSE); } @@ -1197,9 +1195,6 @@ trx_sig_send( in the error state: */ ut_a(0); - - sess_raise_error_low(trx, 0, 0, NULL, NULL, NULL, NULL, - (char *) "Signal from another session, or a break execution signal"); } /* If there were no other signals ahead in the queue, try to start diff --git a/innobase/trx/ts/makefile b/innobase/trx/ts/makefile deleted file mode 100644 index 48e4befcb27..00000000000 --- a/innobase/trx/ts/makefile +++ /dev/null @@ -1,16 +0,0 @@ - - - -include ..\..\makefile.i - -tstrx: ..\trx.lib tstrx.c - $(CCOM) $(CFL) -I.. -I..\.. ..\trx.lib ..\..\pars.lib ..\..\que.lib ..\..\lock.lib ..\..\row.lib ..\..\read.lib ..\..\srv.lib ..\..\com.lib ..\..\usr.lib ..\..\thr.lib ..\..\btr.lib ..\..\fut.lib ..\..\fsp.lib ..\..\page.lib ..\..\dyn.lib ..\..\mtr.lib ..\..\log.lib ..\..\rem.lib ..\..\fil.lib ..\..\buf.lib ..\..\dict.lib ..\..\data.lib ..\..\mach.lib ..\..\ha.lib ..\..\ut.lib ..\..\sync.lib ..\..\mem.lib ..\..\os.lib tstrx.c $(LFL) - - - - - - - - - diff --git a/innobase/trx/ts/tstrx.c b/innobase/trx/ts/tstrx.c deleted file mode 100644 index f69c02dd51e..00000000000 --- a/innobase/trx/ts/tstrx.c +++ /dev/null @@ -1,1663 +0,0 @@ -/************************************************************************ -Test for the transaction system - -(c) 1994-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "rem0rec.h" -#include "srv0srv.h" -#include "que0que.h" -#include "com0com.h" -#include "usr0sess.h" -#include "lock0lock.h" -#include "trx0roll.h" -#include "row0ins.h" -#include "row0upd.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 1 -#define N_FILES 1 -#define FILE_SIZE 1024 /* must be > 512 */ -#define POOL_SIZE 512 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } else { - ut_a(os_file_set_size(files[i], 8192 * FILE_SIZE, 0)); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space header of space 0. */ - -void -init_space(void) -/*============*/ -{ - mtr_t mtr; - - printf("Init space header\n"); - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - - mtr_commit(&mtr); -} - -/********************************************************************* -Test for table creation. */ - -ulint -test1( -/*==*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND1", 0, DICT_CLUSTERED, - 2); - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, 0, 2); - - dict_mem_index_add_field(index, "COL2", 0); - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - /*-------------------------------------*/ - /* CREATE ANOTHER SECONDARY INDEX */ - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, 0, 2); - - dict_mem_index_add_field(index, "COL2", 0); - dict_mem_index_add_field(index, "COL1", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_5( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.5. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE2", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE2", "IND1", 0, DICT_CLUSTERED, - 2); - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Another test for table creation. */ - -ulint -test1_6( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - dict_index_t* index; - dict_table_t* table; - que_fork_t* fork; - que_thr_t* thr; - trx_t* trx; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 1.5. CREATE TABLE WITH 3 COLUMNS AND WITH 1 INDEX\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - table = dict_mem_table_create("TS_TABLE3", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - /*------------------------------------*/ - /* CREATE TABLE */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = tab_create_graph_create(fork, thr, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_TABLES"); - dict_table_print_by_name("SYS_COLUMNS"); */ - /*-------------------------------------*/ - /* CREATE CLUSTERED INDEX */ - - index = dict_mem_index_create("TS_TABLE3", "IND1", 0, DICT_CLUSTERED, - 2); - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = ind_create_graph_create(fork, thr, index, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* dict_table_print_by_name("SYS_INDEXES"); - dict_table_print_by_name("SYS_FIELDS"); */ - - return(0); -} - -/********************************************************************* -Test for inserts. */ - -ulint -test2( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - byte buf[100]; - ulint count = 0; - ins_node_t* node; - - printf("-------------------------------------------------\n"); - printf("TEST 2. MASSIVE INSERT\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* MASSIVE INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - node = ins_node_create(fork, thr, row, table, heap); - - thr->child = node; - - row_ins_init_sys_fields_at_sql_compile(node->row, node->table, heap); - row_ins_init_sys_fields_at_sql_prepare(node->row, node->table, trx); - - node->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - mem_print_info(); - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - rnd = (rnd + 1) % 200000; - - dtuple_gen_test_tuple3(row, rnd, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - mem_print_info(); - -/* dict_table_print_by_name("TS_TABLE1"); */ - /*-------------------------------------*/ - /* ROLLBACK */ -#ifdef notdefined - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu inserts %lu milliseconds\n", - i, tm - oldtm); - /*-------------------------------------*/ -#endif - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ - count++; - - if (count < 1) { - goto loop; - } - return(0); -} - -/********************************************************************* -Test for updates. */ - -ulint -test3( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - byte* ptr; - ulint len; - ulint err; - - UT_NOT_USED(arg); - - printf("-------------------------------------------------\n"); - printf("TEST 3. UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 3; i++) { - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* UPDATE ROWS */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - dtuple_gen_test_tuple3(row, 1, DTUPLE_TEST_FIXED30, buf); - entry = dtuple_create(heap, 2); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - dfield_copy(dtuple_get_nth_field(entry, 1), - dtuple_get_nth_field(row, 1)); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(tree, entry, PAGE_CUR_G, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - ufield->col_no = 2; - dfield_set_data(&(ufield->new_val), "updated field", 14); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - mtr_start(&mtr); - - ut_a(btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr)); - - ptr = rec_get_nth_field(btr_pcur_get_rec(&pcur), 5, &len); - - ut_a(ut_memcmp(ptr, "updated field", 14) == 0); - - btr_pcur_commit(&pcur); - - dict_table_print_by_name("TS_TABLE1"); - - ufield = upd_get_nth_field(update, 0); - - ufield->col_no = 0; - dfield_set_data(&(ufield->new_val), "31415926", 9); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* ROLLBACK */ -#ifdef notdefined - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ -#endif - dict_table_print_by_name("TS_TABLE1"); - count++; - - if (count < 1) { - goto loop; - } - return(0); -} - -/********************************************************************* -Test for massive updates. */ - -ulint -test4( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - ulint j; - ulint rnd; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - byte* ptr; - ulint len; - ulint err; - - printf("-------------------------------------------------\n"); - printf("TEST 4. MASSIVE UPDATES\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); -loop: - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < *((ulint*)arg); i++) { - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - } - - tm = ut_clock(); - printf("Wall time for %lu inserts %lu milliseconds\n", i, tm - oldtm); - -#ifdef notdefined - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* UPDATE ROWS */ - ut_a(trx_start(trx, ULINT_UNDEFINED)); -#endif - fork = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE1", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - update = upd_create(1, heap); - - node = upd_node_create(fork, thr, table, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = 0; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - for (j = 0; j < 2; j++) { - for (i = 0; i < *((ulint*)arg); i++) { - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - entry = dtuple_create(heap, 2); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - dfield_copy(dtuple_get_nth_field(entry, 1), - dtuple_get_nth_field(row, 1)); - - index = dict_table_get_first_index(table); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(tree, entry, PAGE_CUR_G, BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_store_position(&pcur, &mtr); - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - btr_pcur_commit(&pcur); - - ufield = upd_get_nth_field(update, 0); - - ufield->col_no = 2; - dfield_set_data(&(ufield->new_val), "updated field", 14); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - } - mtr_start(&mtr); - - ut_a(btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr)); - - ptr = rec_get_nth_field(btr_pcur_get_rec(&pcur), 5, &len); - - ut_a(ut_memcmp(ptr, "updated field", 14) == 0); - - btr_pcur_commit(&pcur); - - dict_table_print_by_name("TS_TABLE1"); - - ufield = upd_get_nth_field(update, 0); - - ufield->col_no = 0; - dfield_set_data(&(ufield->new_val), "31415926", 9); - - mutex_enter(&kernel_mutex); - - ut_a( - thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - dict_table_print_by_name("TS_TABLE1"); - /*-------------------------------------*/ - /* ROLLBACK */ - - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = roll_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for rollback of %lu updates %lu milliseconds\n", - i, tm - oldtm); -#ifdef notdefined - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - oldtm = ut_clock(); - - que_run_threads(thr); - - tm = ut_clock(); - printf("Wall time for commit %lu milliseconds\n", tm - oldtm); - - /*-------------------------------------*/ -#endif - dict_table_print_by_name("TS_TABLE1"); - count++; - - if (count < 1) { - goto loop; - } - return(0); -} - -/********************************************************************* -Init TS_TABLE2 for TPC-A transaction. */ - -ulint -test4_5( -/*====*/ - void* arg) -{ - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork; - dict_table_t* table; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - byte buf[100]; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 4_5. INIT FOR TPC-A\n"); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - /*-------------------------------------*/ - /* INSERT INTO TABLE TO UPDATE */ - - for (i = 0; i < 100; i++) { - fork = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - table = dict_table_get("TS_TABLE2", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - thr->child = ins_node_create(fork, thr, row, table, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - mutex_exit(&kernel_mutex); - - dtuple_gen_test_tuple3(row, i, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } -/* dict_table_print_by_name("TS_TABLE2"); */ - - /*-------------------------------------*/ - /* COMMIT */ - fork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - fork->trx = trx; - - thr = que_thr_create(fork, fork, heap); - - thr->child = commit_node_create(fork, thr, heap); - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork, trx->sess); - - trx->graph = fork; - - ut_a(thr == que_fork_start_command(fork, SESS_COMM_EXECUTE, 0)); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - /*-----------------------------------*/ - - return(0); -} - -/********************************************************************* -Test for TPC-A transaction. */ - -ulint -test5( -/*==*/ - void* arg) -{ - ulint tm, oldtm; - sess_t* sess; - com_endpoint_t* com_endpoint; - mem_heap_t* heap; - que_fork_t* fork1; - que_fork_t* fork2; - que_fork_t* cfork; - dict_table_t* table; - dict_table_t* table2; - que_thr_t* thr; - trx_t* trx; - ulint i; - dtuple_t* row; - dtuple_t* entry; - byte buf[100]; - ulint count = 0; - btr_pcur_t pcur; - upd_t* update; - upd_field_t* ufield; - dict_tree_t* tree; - dict_index_t* index; - mtr_t mtr; - upd_node_t* node; - ulint err; - ins_node_t* inode; - - arg = arg; - - printf("-------------------------------------------------\n"); - printf("TEST 5. TPC-A %lu \n", *((ulint*)arg)); - - oldtm = ut_clock(); - - heap = mem_heap_create(512); - - com_endpoint = (com_endpoint_t*)heap; /* This is a dummy non-NULL - value */ - mutex_enter(&kernel_mutex); - - sess = sess_open(ut_dulint_zero, com_endpoint, (byte*)"user1", 6); - - trx = sess->trx; - - mutex_exit(&kernel_mutex); - - ut_a(trx_start(trx, ULINT_UNDEFINED)); - /*-----------------------------------*/ - - fork1 = que_fork_create(NULL, NULL, QUE_FORK_INSERT, heap); - fork1->trx = trx; - - thr = que_thr_create(fork1, fork1, heap); - - table = dict_table_get("TS_TABLE3", trx); - - row = dtuple_create(heap, 3 + DATA_N_SYS_COLS); - - dict_table_copy_types(row, table); - - inode = ins_node_create(fork1, thr, row, table, heap); - - thr->child = inode; - - row_ins_init_sys_fields_at_sql_compile(inode->row, inode->table, heap); - row_ins_init_sys_fields_at_sql_prepare(inode->row, inode->table, trx); - - inode->init_all_sys_fields = FALSE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork1, trx->sess); - - trx->graph = fork1; - - mutex_exit(&kernel_mutex); - - fork2 = que_fork_create(NULL, NULL, QUE_FORK_UPDATE, heap); - fork2->trx = trx; - - thr = que_thr_create(fork2, fork2, heap); - - table2 = dict_table_get("TS_TABLE2", trx); - - update = upd_create(1, heap); - - entry = dtuple_create(heap, 2); - dfield_copy(dtuple_get_nth_field(entry, 0), - dtuple_get_nth_field(row, 0)); - dfield_copy(dtuple_get_nth_field(entry, 1), - dtuple_get_nth_field(row, 1)); - - node = upd_node_create(fork2, thr, table2, &pcur, update, heap); - thr->child = node; - - node->cmpl_info = UPD_NODE_NO_ORD_CHANGE | UPD_NODE_NO_SIZE_CHANGE; - - mutex_enter(&kernel_mutex); - - que_graph_publish(fork2, trx->sess); - - trx->graph = fork2; - - mutex_exit(&kernel_mutex); - - cfork = que_fork_create(NULL, NULL, QUE_FORK_EXECUTE, heap); - cfork->trx = trx; - - thr = que_thr_create(cfork, cfork, heap); - - thr->child = commit_node_create(cfork, thr, heap); - - oldtm = ut_clock(); -loop: - /*-------------------------------------*/ - /* INSERT */ - -/* printf("Trx %lu %lu starts, thr %lu\n", - ut_dulint_get_low(trx->id), - (ulint)trx, - *((ulint*)arg)); */ - - dtuple_gen_test_tuple3(row, count, DTUPLE_TEST_FIXED30, buf); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork1, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - /*-------------------------------------*/ - /* 3 UPDATES */ - - for (i = 0; i < 3; i++) { - - dtuple_gen_search_tuple3(entry, *((ulint*)arg), buf); - - index = dict_table_get_first_index(table2); - tree = dict_index_get_tree(index); - - btr_pcur_set_mtr(&pcur, &mtr); - - mtr_start(&mtr); - - btr_pcur_open(tree, entry, PAGE_CUR_G, BTR_MODIFY_LEAF, &pcur, &mtr); - -/* btr_pcur_store_position(&pcur, &mtr); */ - - err = lock_clust_rec_read_check_and_lock(0, btr_pcur_get_rec(&pcur), - index, LOCK_X, thr); - ut_a(err == DB_SUCCESS); - - ufield = upd_get_nth_field(update, 0); - - ufield->col_no = 2; - dfield_set_data(&(ufield->new_val), - "updated field1234567890123456", 30); - - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(fork2, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - - } /* for (i = ... */ - - /*-------------------------------------*/ - /* COMMIT */ -#ifdef notdefined - mutex_enter(&kernel_mutex); - - thr = que_fork_start_command(cfork, SESS_COMM_EXECUTE, 0); - - mutex_exit(&kernel_mutex); - - que_run_threads(thr); - -/* printf("Trx %lu %lu committed\n", ut_dulint_get_low(trx->id), - (ulint)trx); */ -#endif - count++; - - if (count < 1000) { - ut_a(trx_start(trx, ULINT_UNDEFINED)); - - goto loop; - } - - tm = ut_clock(); - printf("Wall time for TPC-A %lu trxs %lu milliseconds\n", - count, tm - oldtm); - - /*-------------------------------------*/ -/* dict_table_print_by_name("TS_TABLE2"); - dict_table_print_by_name("TS_TABLE3"); */ - - return(0); -} - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - os_thread_id_t id[5]; - ulint n1000[5]; - ulint i; - ulint n5000 = 500; - - srv_boot("initfile"); - os_aio_init(160, 5); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - - create_files(); - init_space(); - - sess_sys_init_at_db_start(); - - trx_sys_create(); - - lock_sys_create(1024); - - dict_create(); - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(NULL); - test1_5(NULL); - test1_6(NULL); - test4_5(NULL); - - for (i = 1; i < 5; i++) { - n1000[i] = i; - id[i] = id[i]; -/* os_thread_create(test5, n1000 + i, id + i); */ - } - -/* mem_print_info(); */ - -/* test2(&n5000); */ - - n5000 = 30; - - test5(&n5000); - - n5000 = 30; -/* test5(&n5000); */ - -/* mem_print_info(); */ - -/* dict_table_print_by_name("TS_TABLE1"); */ - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/trx/ts/tsttrxold.c b/innobase/trx/ts/tsttrxold.c deleted file mode 100644 index 13faa7ac79f..00000000000 --- a/innobase/trx/ts/tsttrxold.c +++ /dev/null @@ -1,1089 +0,0 @@ -/************************************************************************ -Test for the transaction system - -(c) 1994-1997 Innobase Oy - -Created 2/16/1996 Heikki Tuuri -*************************************************************************/ - -#include "sync0sync.h" -#include "ut0mem.h" -#include "mem0mem.h" -#include "data0data.h" -#include "data0type.h" -#include "dict0dict.h" -#include "buf0buf.h" -#include "os0file.h" -#include "fil0fil.h" -#include "fsp0fsp.h" -#include "rem0rec.h" -#include "rem0cmp.h" -#include "mtr0mtr.h" -#include "log0log.h" -#include "page0page.h" -#include "page0cur.h" -#include "trx0trx.h" -#include "dict0boot.h" -#include "trx0sys.h" -#include "dict0crea.h" -#include "btr0btr.h" -#include "btr0pcur.h" -#include "rem0rec.h" - -os_file_t files[1000]; - -mutex_t ios_mutex; -ulint ios; -ulint n[10]; - -mutex_t incs_mutex; -ulint incs; - -byte bigbuf[1000000]; - -#define N_SPACES 1 -#define N_FILES 1 -#define FILE_SIZE 4000 /* must be > 512 */ -#define POOL_SIZE 1000 -#define COUNTER_OFFSET 1500 - -#define LOOP_SIZE 150 -#define N_THREADS 5 - - -ulint zero = 0; - -buf_block_t* bl_arr[POOL_SIZE]; - -/************************************************************************ -Io-handler thread function. */ - -ulint -handler_thread( -/*===========*/ - void* arg) -{ - ulint segment; - void* mess; - ulint i; - bool ret; - - segment = *((ulint*)arg); - - printf("Io handler thread %lu starts\n", segment); - - for (i = 0;; i++) { - ret = fil_aio_wait(segment, &mess); - ut_a(ret); - - buf_page_io_complete((buf_block_t*)mess); - - mutex_enter(&ios_mutex); - ios++; - mutex_exit(&ios_mutex); - - } - - return(0); -} - -/************************************************************************* -Creates the files for the file system test and inserts them to -the file system. */ - -void -create_files(void) -/*==============*/ -{ - bool ret; - ulint i, k; - char name[20]; - os_thread_t thr[5]; - os_thread_id_t id[5]; - - printf("--------------------------------------------------------\n"); - printf("Create or open database files\n"); - - strcpy(name, "tsfile00"); - - for (k = 0; k < N_SPACES; k++) { - for (i = 0; i < N_FILES; i++) { - - name[6] = (char)((ulint)'0' + k); - name[7] = (char)((ulint)'0' + i); - - files[i] = os_file_create(name, OS_FILE_CREATE, - OS_FILE_TABLESPACE, &ret); - - if (ret == FALSE) { - ut_a(os_file_get_last_error() == - OS_FILE_ALREADY_EXISTS); - - files[i] = os_file_create( - name, OS_FILE_OPEN, - OS_FILE_TABLESPACE, &ret); - - ut_a(ret); - } - - ret = os_file_close(files[i]); - ut_a(ret); - - if (i == 0) { - fil_space_create(name, k, OS_FILE_TABLESPACE); - } - - ut_a(fil_validate()); - - fil_node_create(name, FILE_SIZE, k); - } - } - - ios = 0; - - mutex_create(&ios_mutex); - - for (i = 0; i < 5; i++) { - n[i] = i; - - thr[i] = os_thread_create(handler_thread, n + i, id + i); - } -} - -/************************************************************************ -Inits space header of space 0. */ - -void -init_space(void) -/*============*/ -{ - mtr_t mtr; - - printf("Init space header\n"); - - mtr_start(&mtr); - - fsp_header_init(0, FILE_SIZE * N_FILES, &mtr); - - mtr_commit(&mtr); -} - -#ifdef notdefined - -/********************************************************************* -Test for index page. */ - -void -test1(void) -/*=======*/ -{ - dtuple_t* tuple; - mem_heap_t* heap; - mem_heap_t* heap2; - ulint rnd = 0; - dict_index_t* index; - dict_table_t* table; - byte buf[16]; - ulint i, j; - ulint tm, oldtm; - trx_t* trx; -/* dict_tree_t* tree;*/ - btr_pcur_t pcur; - btr_pcur_t pcur2; - mtr_t mtr; - mtr_t mtr2; - byte* field; - ulint len; - dtuple_t* search_tuple; - dict_tree_t* index_tree; - rec_t* rec; - - UT_NOT_USED(len); - UT_NOT_USED(field); - UT_NOT_USED(pcur2); -/* - printf("\n\n\nPress 2 x enter to start test\n"); - - while (EOF == getchar()) { - - } - - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 1. CREATE TABLE WITH 3 COLUMNS AND WITH 3 INDEXES\n"); - - heap = mem_heap_create(1024); - heap2 = mem_heap_create(1024); - - trx = trx_start(ULINT_UNDEFINED); - - table = dict_mem_table_create("TS_TABLE1", 0, 3); - - dict_mem_table_add_col(table, "COL1", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL2", DATA_VARCHAR, - DATA_ENGLISH, 10, 0); - dict_mem_table_add_col(table, "COL3", DATA_VARCHAR, - DATA_ENGLISH, 100, 0); - - ut_a(TRUE == dict_create_table(table, trx)); - - index = dict_mem_index_create("TS_TABLE1", "IND1", 75046, - DICT_CLUSTERED, 2); - - dict_mem_index_add_field(index, "COL1", 0); - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - ut_a(TRUE == dict_create_index(index, trx)); - - trx_commit(trx); - - trx = trx_start(ULINT_UNDEFINED); - - index = dict_mem_index_create("TS_TABLE1", "IND2", 0, DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - ut_a(TRUE == dict_create_index(index, trx)); - - trx_commit(trx); - - trx = trx_start(ULINT_UNDEFINED); - - index = dict_mem_index_create("TS_TABLE1", "IND3", 0, DICT_UNIQUE, 1); - - dict_mem_index_add_field(index, "COL2", 0); - - ut_a(mem_heap_validate(index->heap)); - - ut_a(TRUE == dict_create_index(index, trx)); - - trx_commit(trx); -/* - tree = dict_index_get_tree(dict_table_get_first_index(table)); - - btr_print_tree(tree, 10); -*/ - dict_table_print(table); - - /*---------------------------------------------------------*/ -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 2. INSERT 1 ROW TO THE TABLE\n"); - - trx = trx_start(ULINT_UNDEFINED); - - tuple = dtuple_create(heap, 3); - - table = dict_table_get("TS_TABLE1", trx); - - dtuple_gen_test_tuple3(tuple, 0, buf); - tcur_insert(tuple, table, heap2, trx); - - trx_commit(trx); -/* - tree = dict_index_get_tree(dict_table_get_first_index(table)); - - btr_print_tree(tree, 10); -*/ -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 3. INSERT MANY ROWS TO THE TABLE IN A SINGLE TRX\n"); - - rnd = 0; - oldtm = ut_clock(); - - trx = trx_start(ULINT_UNDEFINED); - for (i = 0; i < 300 * UNIV_DBC * UNIV_DBC; i++) { - - if (i % 5000 == 0) { - /* dict_table_print(table); - buf_print(); - buf_LRU_print(); - printf("%lu rows inserted\n", i); */ - } - - table = dict_table_get("TS_TABLE1", trx); - - if (i == 2180) { - rnd = rnd % 200000; - } - - rnd = (rnd + 1) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - tcur_insert(tuple, table, heap2, trx); - - mem_heap_empty(heap2); - - if (i % 4 == 3) { - } - } - trx_commit(trx); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("%lu rows inserted\n", i); -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 4. PRINT PART OF CONTENTS OF EACH INDEX TREE\n"); - -/* - mem_print_info(); -*/ - -/* - tree = dict_index_get_tree(dict_table_get_first_index(table)); - - btr_print_tree(tree, 10); - - tree = dict_index_get_tree(dict_table_get_next_index( - dict_table_get_first_index(table))); - - btr_print_tree(tree, 5); -*/ -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ -/* mem_print_info(); */ - - os_thread_sleep(5000000); - - for (j = 0; j < 5; j++) { - printf("-------------------------------------------------\n"); - printf("TEST 5. CALCULATE THE JOIN OF THE TABLE WITH ITSELF\n"); - - i = 0; - - oldtm = ut_clock(); - - mtr_start(&mtr); - - index_tree = dict_index_get_tree(UT_LIST_GET_FIRST(table->indexes)); - - search_tuple = dtuple_create(heap, 2); - - dtuple_gen_search_tuple3(search_tuple, i, buf); - - btr_pcur_open(index_tree, search_tuple, PAGE_CUR_GE, - BTR_SEARCH_LEAF, &pcur, &mtr); - - ut_a(btr_pcur_move_to_next(&pcur, &mtr)); - - while (!btr_pcur_is_after_last_in_tree(&pcur, &mtr)) { - - if (i % 20000 == 0) { - printf("%lu rows joined\n", i); - } - - index_tree = dict_index_get_tree( - UT_LIST_GET_FIRST(table->indexes)); - - rec = btr_pcur_get_rec(&pcur); - - rec_copy_prefix_to_dtuple(search_tuple, rec, 2, heap2); - - mtr_start(&mtr2); - - btr_pcur_open(index_tree, search_tuple, PAGE_CUR_GE, - BTR_SEARCH_LEAF, &pcur2, &mtr2); - - btr_pcur_move_to_next(&pcur2, &mtr2); - - rec = btr_pcur_get_rec(&pcur2); - - field = rec_get_nth_field(rec, 1, &len); - - ut_a(len == 8); - - ut_a(ut_memcmp(field, dfield_get_data( - dtuple_get_nth_field(search_tuple, 1)), - len) == 0); - - btr_pcur_close(&pcur2, &mtr); - - mem_heap_empty(heap2); - - mtr_commit(&mtr2); - - btr_pcur_store_position(&pcur, &mtr); - mtr_commit(&mtr); - - mtr_start(&mtr); - - btr_pcur_restore_position(BTR_SEARCH_LEAF, &pcur, &mtr); - - btr_pcur_move_to_next(&pcur, &mtr); - i++; - } - - btr_pcur_close(&pcur, &mtr); - mtr_commit(&mtr); - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("%lu rows joined\n", i); - } - - oldtm = ut_clock(); - -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 6. INSERT MANY ROWS TO THE TABLE IN SEPARATE TRXS\n"); - - rnd = 200000; - - for (i = 0; i < 350; i++) { - - if (i % 4 == 0) { - } - trx = trx_start(ULINT_UNDEFINED); - - table = dict_table_get("TS_TABLE1", trx); - - if (i == 2180) { - rnd = rnd % 200000; - } - - rnd = (rnd + 1) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - tcur_insert(tuple, table, heap2, trx); - - trx_commit(trx); - - mem_heap_empty(heap2); - if (i % 4 == 3) { - } - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("%lu rows inserted in %lu transactions\n", i, i); -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 7. PRINT MEMORY ALLOCATION INFO\n"); - - mem_print_info(); -/* - printf("\n\n\nPress 2 x enter to continue test\n"); - - while (EOF == getchar()) { - - } - getchar(); -*/ - printf("-------------------------------------------------\n"); - printf("TEST 8. PRINT SEMAPHORE INFO\n"); - - sync_print(); - -#endif - -#ifdef notdefined - rnd = 90000; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - if (i == 50000) { - rnd = rnd % 200000; - } - - rnd = (rnd + 595659561) % 200000; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - btr_pcur_open(tree, tuple, PAGE_CUR_GE, - BTR_SEARCH_LEAF, &cursor, &mtr); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - - rnd = 0; - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - rnd = (rnd + 35608971) % 200000 + 1; - - dtuple_gen_test_tuple3(tuple, rnd, buf); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - -/* btr_print_tree(tree, 3); */ - -#endif -/* - mem_heap_free(heap); -} -*/ - -#ifdef notdefined - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 534671) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - -/* page_print_list(page, 151); */ - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 7771) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_get_n_recs(page) == 0); - - ut_a(page_validate(page, index)); - page = page_create(frame, &mtr); - - rnd = 311; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 217; - - for (i = 0; i < 512; i++) { - - rnd = (rnd + 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - page = page_create(frame, &mtr); - - rnd = 291; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 512); - - rnd = 277; - - for (i = 0; i < 512; i++) { - - rnd = (rnd - 1) % 512; - - if (i % 27 == 0) { - ut_a(page_validate(page, index)); - } - - dtuple_gen_test_tuple(tuple, rnd); - -/* dtuple_print(tuple);*/ - - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - - ut_a(rec); - - rec_validate(rec); -/* page_print_list(page, 151); */ - } - - ut_a(page_validate(page, index)); - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - mem_heap_free(heap); -} - -/********************************************************************* -Test for index page. */ - -void -test2(void) -/*=======*/ -{ - page_t* page; - dtuple_t* tuple; - mem_heap_t* heap; - ulint i, j; - ulint rnd = 0; - rec_t* rec; - page_cur_t cursor; - dict_index_t* index; - dict_table_t* table; - buf_block_t* block; - buf_frame_t* frame; - ulint tm, oldtm; - byte buf[8]; - mtr_t mtr; - - printf("-------------------------------------------------\n"); - printf("TEST 2. Speed test\n"); - - oldtm = ut_clock(); - - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf, bigbuf + 800, 800); - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - oldtm = ut_clock(); - - rnd = 0; - for (i = 0; i < 1000 * UNIV_DBC * UNIV_DBC; i++) { - ut_memcpy(bigbuf + rnd, bigbuf + rnd + 800, 800); - rnd += 1600; - if (rnd > 995000) { - rnd = 0; - } - } - - tm = ut_clock(); - printf("Wall time for %lu mem copys of 800 bytes %lu millisecs\n", - i, tm - oldtm); - - heap = mem_heap_create(0); - - table = dict_table_create("TS_TABLE2", 2); - - dict_table_add_col(table, "COL1", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - dict_table_add_col(table, "COL2", DATA_VARCHAR, DATA_ENGLISH, 10, 0); - - ut_a(0 == dict_table_publish(table)); - - index = dict_index_create("TS_TABLE2", "IND2", 0, 2, 0); - - dict_index_add_field(index, "COL1", 0); - dict_index_add_field(index, "COL2", 0); - - ut_a(0 == dict_index_publish(index)); - - index = dict_index_get("TS_TABLE2", "IND2"); - ut_a(index); - - tuple = dtuple_create(heap, 2); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_get(0, 5, &mtr); - buf_page_s_lock(block, &mtr); - - page = buf_block_get_frame(block); - ut_a(page_validate(page, index)); - mtr_commit(&mtr); - - oldtm = ut_clock(); - - rnd = 677; - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for %lu empty loops with page create %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 100; - for (j = 0; j < 250; j++) { - rnd = (rnd + 1) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for sequential insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 500; - for (j = 0; j < 250; j++) { - rnd = (rnd - 1) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf( - "Wall time for descend. seq. insertion of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - page_cur_delete_rec(&cursor, &mtr); - } - ut_a(page_get_n_recs(page) == 0); - - mtr_commit(&mtr); - } - - tm = ut_clock(); - printf("Wall time for insert and delete of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - mtr_start(&mtr); - - block = buf_page_create(0, 5, &mtr); - buf_page_x_lock(block, &mtr); - - frame = buf_block_get_frame(block); - - page = page_create(frame, &mtr); - - rnd = 677; - - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - - rec = page_cur_insert_rec(&cursor, tuple, NULL, &mtr); - ut_a(rec); - } - ut_a(page_validate(page, index)); - mtr_print(&mtr); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - page_cur_search(page, tuple, PAGE_CUR_G, &cursor); - } - } - - tm = ut_clock(); - printf("Wall time for search of %lu recs %lu milliseconds\n", - i * j, tm - oldtm); - - oldtm = ut_clock(); - - for (i = 0; i < 4 * UNIV_DBC * UNIV_DBC; i++) { - rnd = 677; - for (j = 0; j < 250; j++) { - rnd = (rnd + 54841) % 1000; - dtuple_gen_test_tuple2(tuple, rnd, buf); - } - } - - tm = ut_clock(); - printf("Wall time for %lu empty loops %lu milliseconds\n", - i * j, tm - oldtm); - mtr_commit(&mtr); -} - -#endif - -/******************************************************************** -Main test function. */ - -void -main(void) -/*======*/ -{ - ulint tm, oldtm; - mtr_t mtr; - - sync_init(); - mem_init(); - os_aio_init(160, 5); - fil_init(25); - buf_pool_init(POOL_SIZE, POOL_SIZE); - fsp_init(); - log_init(); - - create_files(); - init_space(); - - mtr_start(&mtr); - - trx_sys_create(&mtr); - dict_create(&mtr); - - mtr_commit(&mtr); - - - oldtm = ut_clock(); - - ut_rnd_set_seed(19); - - test1(); - -/* mem_print_info(); */ - - tm = ut_clock(); - printf("Wall time for test %lu milliseconds\n", tm - oldtm); - printf("TESTS COMPLETED SUCCESSFULLY!\n"); -} diff --git a/innobase/usr/usr0sess.c b/innobase/usr/usr0sess.c index d74153e323f..1455a16057e 100644 --- a/innobase/usr/usr0sess.c +++ b/innobase/usr/usr0sess.c @@ -29,6 +29,13 @@ Created 6/25/1996 Heikki Tuuri sess_sys_t* sess_sys = NULL; /************************************************************************* +Closes a session, freeing the memory occupied by it. */ +static +void +sess_close( +/*=======*/ + sess_t* sess); /* in, own: session object */ +/************************************************************************* Communicates an error message to the client. If sess->client_waits is not TRUE, puts the session to error state and does not try to send the error message. */ @@ -85,42 +92,6 @@ sess_cli_msg_set_sess( mach_write_to_4(str + SESS_CLI_MSG_SESS_ID_CHECK, fold); } -/************************************************************************* -Returns the session to which a message from a client is addressed. -NOTE: this function does not assume that the message is uncorrupted. */ -static -sess_t* -sess_cli_msg_get_sess( -/*==================*/ - /* out: session, NULL if not found */ - byte* str, /* in: message string */ - ulint len) /* in: message string length */ -{ - sess_t* sess; - ulint fold; - dulint id; - - ut_ad(mutex_own(&kernel_mutex)); - - if (len < SESS_CLI_MSG_SESS_ID_CHECK + 4) { - - return(NULL); - } - - id = mach_read_from_8(str + SESS_CLI_MSG_SESS_ID); - - fold = sess_id_fold(id); - - if (fold != mach_read_from_4(str + SESS_CLI_MSG_SESS_ID_CHECK)) { - - return(NULL); - } - - HASH_SEARCH(hash, sess_sys->hash, fold, sess, - UT_DULINT_EQ(id, sess->id)); - return(sess); -} - /*************************************************************************** Decrements the reference count of a session and closes it, if desired. */ UNIV_INLINE @@ -311,6 +282,7 @@ sess_open( /************************************************************************* Closes a session, freeing the memory occupied by it. */ +static void sess_close( /*=======*/ @@ -595,329 +567,6 @@ sess_error_low( NULL, NULL, NULL); } -/************************************************************************* -Raises an SQL error. */ - -void -sess_raise_error_low( -/*=================*/ - trx_t* trx, /* in: transaction */ - ulint err_no, /* in: error number */ - ulint type, /* in: more info of the error, or 0 */ - dict_table_t* table, /* in: dictionary table or NULL */ - dict_index_t* index, /* in: table index or NULL */ - dtuple_t* tuple, /* in: tuple to insert or NULL */ - rec_t* rec, /* in: record or NULL */ - char* err_str)/* in: arbitrary null-terminated error string, - or NULL */ -{ - char* str; - ulint len; - - ut_ad(mutex_own(&kernel_mutex)); - - str = mem_alloc(64000); - - len = 0; - - len += sprintf(str + len, "Error number: %lu", (ulong) err_no); - - if (type) { - len += sprintf(str + len, ", type: %lu", (ulong) type); - } - - if (table) { - len += sprintf(str + len, ", table: %s", table->name); - } - - if (index) { - len += sprintf(str + len, ", index: %s", index->name); - } - - if (tuple) { - len += sprintf(str + len, ", tuple:"); - len += dtuple_sprintf(str + len, 8192, tuple); - } - - if (rec) { - len += sprintf(str + len, ", record:"); - len += rec_sprintf(str + len, 8192, rec); - } - - if (err_str) { - len += sprintf(str + len, ", %s", err_str); - } - - str[len] = '\0'; - - ut_a(len < 64000); - - if (trx->sess) { - sess_error_low(trx->sess, err_no, str); - } else { - mem_free(str); - } -} - -/*************************************************************************** -Processes a client message which is part of a bigger message. */ -static -ibool -sess_receive_msg_part( -/*==================*/ - /* TRUE if message completed */ - sess_t* sess, /* in: session */ - byte* str, /* in: message string */ - ulint len) /* in: message length */ -{ - ulint cont; - - cont = sess_cli_msg_get_continue(str); - - ut_ad(cont != SESS_MSG_SINGLE_PART); - - if (cont == SESS_MSG_FIRST_PART) { - if (sess->big_msg) { - sess_error_low(sess, SESS_ERR_MSG_LOST, NULL); - - return(FALSE); - } - - sess->big_msg_size = 1024 * sess_cli_msg_get_cont_size(str); - sess->big_msg = mem_alloc(sess->big_msg_size); - - if (sess->big_msg == NULL) { - sess_error_low(sess, SESS_ERR_OUT_OF_MEMORY, NULL); - - return(FALSE); - } - - ut_memcpy(sess->big_msg, str, len); - sess->big_msg_len = len; - - return(FALSE); - } else { - if (sess->big_msg == NULL) { - sess_error_low(sess, SESS_ERR_MSG_LOST, NULL); - - return(FALSE); - } - - ut_memcpy(sess->big_msg + sess->big_msg_len, - str + SESS_CLI_MSG_DATA, len - SESS_CLI_MSG_DATA); - - sess->big_msg_len += len - SESS_CLI_MSG_DATA; - - if (cont == SESS_MSG_MIDDLE_PART) { - - return(FALSE); - } - - return(TRUE); - } -} - -/*************************************************************************** -Processes a client message which requires SQL parsing. This function decodes -the client message built in SQLPrepare. NOTE: The kernel mutex is temporarily -released within this function. */ -static -void -sess_receive_prepare( -/*=================*/ - sess_t* sess, /* in: session */ - byte* cli_msg,/* in: client message */ - ulint len) /* in: message length */ -{ - dulint error_count; - que_t* graph; - byte msg[ODBC_DATAGRAM_SIZE]; - - UT_NOT_USED(len); - - ut_ad(mutex_own(&kernel_mutex)); - - error_count = sess->error_count; - - /* Make sure the session object is not freed during the parsing */ - - sess_refer_count_inc(sess); - - /* We release the kernel mutex before parsing the command: this is - to reduce contention on the kernel mutex */ - - mutex_exit(&kernel_mutex); - -/* printf("To parse query %s\n", (char*)(cli_msg + SESS_CLI_MSG_DATA)); */ - - graph = pars_sql((char*)(cli_msg + SESS_CLI_MSG_DATA)); - - mutex_enter(&kernel_mutex); - - if (graph == NULL) { - /* Error in parsing */ - sess_error_low(sess, SESS_ERR_SQL_ERROR, NULL); - - sess_refer_count_dec(sess); - - ut_error; - - return; - } - - if (!UT_DULINT_EQ(error_count, sess->error_count)) { - - /* An error, or an asyncronous signal on the session happened - when the kernel mutex was not reserved: discard graph */ - - graph->state = QUE_FORK_INVALID; - - que_graph_try_free(graph); - - sess_refer_count_dec(sess); - - ut_error; - - return; - } - - UT_LIST_ADD_LAST(graphs, sess->graphs, graph); - - graph->id = sess->next_graph_id; - sess->next_graph_id++; - - /* Tell the client that the preparation succeeded and communicate info - about the possible query parameters: the message will be decoded in - SQLPrepare */ - - ut_ad(sess->client_waits); - - sess_srv_msg_init(sess, msg, SESS_SRV_SUCCESS); - - mach_write_to_4(msg + SESS_SRV_MSG_DATA, graph->id); - - mutex_exit(&kernel_mutex); - - len = pars_write_query_param_info(msg + SESS_SRV_MSG_DATA + 4, graph); - - mutex_enter(&kernel_mutex); - - sess_srv_msg_send(sess, msg, SESS_SRV_MSG_DATA + 4 + len, - SESS_RELEASE_KERNEL); - sess_refer_count_dec(sess); -} - -/*************************************************************************** -Processes a client message which does not require SQL parsing. This function -decodes the client message built in SQLExecute. */ -static -void -sess_receive_command( -/*=================*/ - sess_t* sess, /* in: session */ - byte* cli_msg,/* in: client message */ - ulint len, /* in: message length */ - ulint type) /* in: message type */ -{ - proc_node_t* proc_node; - call_node_t* call_node; - dict_proc_t* dict_proc; - que_thr_t* thr; - que_t* graph; - ulint stat_id; - - UT_NOT_USED(len); - UT_NOT_USED(type); - - ut_ad(mutex_own(&kernel_mutex)); - - sess->client_waits = TRUE; - - stat_id = mach_read_from_4(cli_msg + SESS_CLI_MSG_DATA); - - /* Look for the statement from the list of query graphs */ - - graph = UT_LIST_GET_FIRST(sess->graphs); - - while (graph != NULL) { - - if (graph->id == stat_id) { - - break; - } - - graph = UT_LIST_GET_NEXT(graphs, graph); - } - - if (graph == NULL) { - /* Could not find the right graph: error */ - sess_error_low(sess, SESS_ERR_STMT_NOT_FOUND, NULL); - - return; - } - - if (graph->state != QUE_FORK_COMMAND_WAIT) { - sess_error_low(sess, SESS_ERR_STMT_NOT_READY, NULL); - - return; - } - -/* printf("To execute stat %lu\n", stat_id); */ - - if (graph->fork_type == QUE_FORK_PROCEDURE_CALL) { - /* It is a stored procedure call: retrieve a parsed copy of - the procedure from the dictionary cache */ - - mutex_exit(&kernel_mutex); - - call_node = que_fork_get_child(graph); - - graph = dict_procedure_reserve_parsed_copy( - call_node->procedure_def); - graph->trx = sess->trx; - - /* Retrieve the procedure input parameters from the message */ - - pars_proc_read_input_params_from_buf(graph, - cli_msg + SESS_CLI_MSG_DATA + 4); - mutex_enter(&kernel_mutex); - } else { - /* It is a create procedure command: add the procedure to the - dictionary cache */ - ut_ad(graph->fork_type == QUE_FORK_PROCEDURE); - - mutex_exit(&kernel_mutex); - - proc_node = que_fork_get_child(graph); - - dict_proc = dict_mem_procedure_create(proc_node->proc_id->name, - proc_node->sym_tab->sql_string, - graph); - - dict_procedure_add_to_cache(dict_proc); - - mutex_enter(&kernel_mutex); - - sess_srv_msg_send_simple(sess, SESS_SRV_SUCCESS, - SESS_RELEASE_KERNEL); - return; - } - - /* Choose a query thread for execution */ - thr = que_fork_start_command(graph, SESS_COMM_EXECUTE, 0); - - ut_ad(thr); - - sess->trx->graph = graph; - - mutex_exit(&kernel_mutex); - - /* Run query threads with the kernel mutex released */ - - que_run_threads(thr); - - mutex_enter(&kernel_mutex); -} /*************************************************************************** When a command has been completed, this function sends the message about it @@ -936,239 +585,3 @@ sess_command_completed_message( SESS_RELEASE_KERNEL); mutex_exit(&kernel_mutex); } - -/*************************************************************************** -Processes a break message from the client. */ -static -void -sess_receive_break( -/*===============*/ - sess_t* sess) /* in: session */ -{ - ut_ad(mutex_own(&kernel_mutex)); - - /* Rollback the latest incomplete SQL statement */ - - sess_error_low(sess, SESS_ERR_BREAK_BY_CLIENT, NULL); -} - -/*************************************************************************** -Processes a message from a client. NOTE: Releases the kernel mutex temporarily -when parsing an SQL string. */ - -void -sess_receive_msg_rel_kernel( -/*========================*/ - sess_t* sess, /* in: session */ - byte* str, /* in: message string */ - ulint len) /* in: message length */ -{ - dulint msg_no; - ulint msg_type; - ulint cont; - ibool is_big_msg = FALSE; - ibool client_waited; - - ut_ad(mutex_own(&kernel_mutex)); - ut_ad(!sess->disconnecting); - - client_waited = sess->client_waits; - - sess->client_waits = TRUE; - - if (sess->state == SESS_ERROR) { - - /* Send a buffered error message */ - sess_srv_msg_send_error(sess); - - return; - } - - if (FALSE == sess_cli_msg_check_consistency(str, len)) { - /* Message from the client was corrupted */ - - sess_error_low(sess, SESS_ERR_MSG_CORRUPTED, NULL); - - return; - } - - msg_no = sess_cli_msg_get_msg_no(str); - - UT_DULINT_INC(sess->msgs_recv); - - if (!UT_DULINT_EQ(msg_no, sess->msgs_recv)) { - - sess_error_low(sess, SESS_ERR_MSG_LOST, NULL); - - sess->msgs_recv = msg_no; - - return; - } - - msg_type = sess_cli_msg_get_type(str); - - if (msg_type == SESS_CLI_BREAK_EXECUTION) { - - sess_receive_break(sess); - - return; - } - - if (client_waited) { - /* Client sent an extraneous message which is not a break - command: an error */ - - sess_error_low(sess, SESS_ERR_EXTRANEOUS_MSG, NULL); - - return; - } - - /*-----------------------------------------------------------*/ - /* Handle big messages */ - - cont = sess_cli_msg_get_continue(str); - - if (cont == SESS_MSG_SINGLE_PART) { - if (sess->big_msg) { - - sess_error_low(sess, SESS_ERR_MSG_LOST, NULL); - - return; - } - } else { - ut_error; /* Not in use */ - - is_big_msg = sess_receive_msg_part(sess, str, len); - - if (is_big_msg) { - str = sess->big_msg; - len = sess->big_msg_len; - sess->big_msg = NULL; - } else { - return; - } - } - - /*-----------------------------------------------------------*/ - /* The session has received a complete message from the client */ - - ut_ad(!UT_LIST_GET_FIRST((sess->trx)->signals)); - - if (msg_type == SESS_CLI_PREPARE) { - /* Note that the kernel mutex is temporarily released when - the SQL string is parsed */ - - sess_receive_prepare(sess, str, len); - } else { - /* Note that the kernel mutex is temporarily released when the - command is executed */ - - sess_receive_command(sess, str, len, msg_type); - } - - if (is_big_msg) { - mem_free(str); - } -} - -/*********************************************************************** -Opens a new connection and creates a session. */ -static -ibool -sess_open_connection( -/*=================*/ - byte* str, /* in: message string */ - ulint len, /* in: string length */ - byte* addr, /* in: user address string */ - ulint alen) /* in: user address length */ -{ - dulint sess_id; - sess_t* sess; - - sess_id = mach_read_from_8(str + SESS_CLI_MSG_SESS_ID); - - if (!(UT_DULINT_EQ(sess_id, ut_dulint_zero)) - || !(sess_cli_msg_get_type(str) == SESS_CLI_CONNECT)) { - - /* It is not a valid connect message */ - - return(FALSE); - } - - ut_a(len == SESS_CLI_MSG_DATA); - - sess = sess_open(srv_sys->endpoint, addr, alen); - - sess_srv_msg_send_simple(sess, SESS_SRV_ACCEPT_CONNECT, - SESS_NOT_RELEASE_KERNEL); - return(TRUE); -} - -/*********************************************************************** -Starts a new connection and a session, or starts a query based on a client -message. This is called by a SRV_COM thread. */ - -void -sess_process_cli_msg( -/*=================*/ - byte* str, /* in: message string */ - ulint len, /* in: string length */ - byte* addr, /* in: address string */ - ulint alen) /* in: address length */ -{ - sess_t* sess; - ibool success; - - UT_NOT_USED(addr); - UT_NOT_USED(alen); - - mutex_enter(&kernel_mutex); - - sess = sess_cli_msg_get_sess(str, len); - - if (sess == NULL) { - /* There was no matching session */ - - if (sess_cli_msg_check_consistency(str, len)) { - - /* As the message is consistent, it may be a connect - message */ - - /* printf("%s\n", addr); */ - - success = sess_open_connection(str, len, addr, alen); - - if (success) { - mutex_exit(&kernel_mutex); - - return; - } - } - - /* Could not make sense of the message: write an error entry - to the system error log */ - - /* srv_err_log_insert( - "MESSAGE SENT TO AN UNKNOWN SESSION");*/ - ut_error; - - mutex_exit(&kernel_mutex); - - return; - } - - if (sess->disconnecting) { - - /* srv_err_log_insert( - "MESSAGE SENT TO A DISCONNECTING SESSION");*/ - ut_error; - - mutex_exit(&kernel_mutex); - - return; - } - - sess_receive_msg_rel_kernel(sess, str, len); - - mutex_exit(&kernel_mutex); -} diff --git a/innobase/ut/ts/makefile b/innobase/ut/ts/makefile deleted file mode 100644 index 5ef15ade794..00000000000 --- a/innobase/ut/ts/makefile +++ /dev/null @@ -1,12 +0,0 @@ - -include ..\..\makefile.i - -tsut: ..\ut.lib tsut.c - $(CCOM) $(CFL) -I.. -I..\.. ..\ut.lib ..\..\os.lib tsut.c $(LFL) - - - - - - - diff --git a/innobase/ut/ts/tsut.c b/innobase/ut/ts/tsut.c deleted file mode 100644 index 81c9ff79f96..00000000000 --- a/innobase/ut/ts/tsut.c +++ /dev/null @@ -1,347 +0,0 @@ -/************************************************************************ -The test module for the utilities - -(c) 1995 Innobase Oy - -Created 10/28/1995 Heikki Tuuri -*************************************************************************/ - -#include "../ut0lst.h" -#include "../ut0mem.h" -#include "../ut0byte.h" -#include "../ut0sort.h" -#include "../ut0rnd.h" - -typedef struct node_struct node_t; -struct node_struct { - ulint index; - ulint zyx; - UT_LIST_NODE_T(node_t) list1; - ulint yzx; - UT_LIST_NODE_T(node_t) list2; -}; - -/* Arrays to be sorted */ -ulint uarr[100000]; -ulint aux_uarr[100000]; -dulint duarr[100000]; -dulint aux_duarr[100000]; - -/********************************************************************* -Tests for two-way lists. */ - -void -test1(void) -/*=======*/ -{ - ulint i; - UT_LIST_BASE_NODE_T(node_t) base1; - UT_LIST_BASE_NODE_T(node_t) base2; - node_t* node; - node_t* node2; - - printf("-------------------------------------------\n"); - printf("TEST 1. Test of two-way lists \n"); - - UT_LIST_INIT(base1); - UT_LIST_INIT(base2); - - for (i = 0; i < 1000; i++) { - node = ut_malloc(sizeof(node_t)); - - node->index = 999 - i; - - UT_LIST_ADD_FIRST(list1, base1, node); - UT_LIST_ADD_LAST(list2, base2, node); - } - - UT_LIST_VALIDATE(list1, node_t, base1); - UT_LIST_VALIDATE(list2, node_t, base2); - - node = UT_LIST_GET_FIRST(base1); - - for (i = 0; i < 1000; i++) { - - ut_a(node); - ut_a(node->index == i); - - node = UT_LIST_GET_NEXT(list1, node); - } - - ut_a(node == NULL); - - node = UT_LIST_GET_FIRST(base2); - - for (i = 0; i < 1000; i++) { - - ut_a(node); - ut_a(node->index == 999 - i); - - node = UT_LIST_GET_NEXT(list2, node); - } - - ut_a(node == NULL); - - UT_LIST_VALIDATE(list1, node_t, base1); - UT_LIST_VALIDATE(list2, node_t, base2); - - node = UT_LIST_GET_FIRST(base1); - - for (i = 0; i < 500; i++) { - - ut_a(node); - ut_a(node->index == i); - - node = UT_LIST_GET_NEXT(list1, node); - } - - for (i = 0; i < 100; i++) { - node2 = ut_malloc(sizeof(node_t)); - - node2->index = 99 - i; - - UT_LIST_INSERT_AFTER(list1, base1, node, node2); - UT_LIST_VALIDATE(list1, node_t, base1); - } - - node2 = ut_malloc(sizeof(node_t)); - node2->index = 1000; - UT_LIST_INSERT_AFTER(list1, base1, UT_LIST_GET_LAST(base1), node2); - - node2 = node; - - for (i = 0; i < 100; i++) { - node2 = UT_LIST_GET_NEXT(list1, node2); - - ut_a(node2); - ut_a(node2->index == i); - } - - UT_LIST_VALIDATE(list1, node_t, base1); - - for (i = 0; i < 600; i++) { - - node2 = UT_LIST_GET_NEXT(list1, node); - - UT_LIST_REMOVE(list1, base1, node2); - UT_LIST_VALIDATE(list1, node_t, base1); - } - - node2 = UT_LIST_GET_NEXT(list1, node); - - UT_LIST_VALIDATE(list1, node_t, base1); - UT_LIST_VALIDATE(list2, node_t, base2); - - ut_a(UT_LIST_GET_LEN(base1) == 501); - - ut_a(UT_LIST_GET_LAST(base1) == node); - - for (i = 0; i < 500; i++) { - - node = UT_LIST_GET_PREV(list1, node); - } - - ut_a(UT_LIST_GET_FIRST(base1) == node); - - for (i = 0; i < 501; i++) { - - node2 = UT_LIST_GET_FIRST(base1); - - UT_LIST_REMOVE(list1, base1, node2); - } - - UT_LIST_VALIDATE(list1, node_t, base1); - UT_LIST_VALIDATE(list2, node_t, base2); - - ut_a(UT_LIST_GET_LEN(base1) == 0); - ut_a(UT_LIST_GET_LEN(base2) == 1000); -} - -/********************************************************************* -Tests for dulints. */ - -void -test2(void) -/*=======*/ -{ - dulint a, b; - - printf("-------------------------------------------\n"); - printf("TEST 2. Test of dulints \n"); - - a = ut_dulint_create(0xFFFFFFFF, 0xFFFFFFFF); - - b = a; - - ut_a(ut_dulint_cmp(a, b) == 0); - - ut_a(ut_dulint_get_low(b) == 0xFFFFFFFF); - ut_a(ut_dulint_get_high(b) == 0xFFFFFFFF); - - a = ut_dulint_create(0xFFFFFFFE, 0xFFFFFFFF); - ut_a(ut_dulint_cmp(a, b) == -1); - ut_a(ut_dulint_cmp(b, a) == 1); - - a = ut_dulint_create(0xFFFFFFFF, 0xFFFFFFFE); - ut_a(ut_dulint_cmp(a, b) == -1); - ut_a(ut_dulint_cmp(b, a) == 1); - - a = ut_dulint_create(5, 0xFFFFFFFF); - - a = ut_dulint_add(a, 5); - - ut_a(ut_dulint_get_low(a) == 4); - ut_a(ut_dulint_get_high(a) == 6); - - a = ut_dulint_create(5, 0x80000000); - - a = ut_dulint_add(a, 0x80000000); - - ut_a(ut_dulint_get_low(a) == 0); - ut_a(ut_dulint_get_high(a) == 6); - - a = ut_dulint_create(5, 10); - - a = ut_dulint_add(a, 20); - - ut_a(ut_dulint_get_low(a) == 30); - ut_a(ut_dulint_get_high(a) == 5); -} - -/*************************************************************** -Comparison function for ulints. */ -UNIV_INLINE -int -cmp_ulint(ulint a, ulint b) -/*=======================*/ -{ - if (a < b) { - return(-1); - } else if (b < a) { - return(1); - } else { - return(0); - } -} - -/**************************************************************** -Sort function for ulint arrays. */ -void -sort_ulint(ulint* arr, ulint* aux_arr, ulint low, ulint high) -/*=========================================================*/ -{ - ut_ad(high <= 100000); - - UT_SORT_FUNCTION_BODY(sort_ulint, arr, aux_arr, low, high, - cmp_ulint); -} - -/**************************************************************** -Sort function for dulint arrays. */ -void -sort_dulint(dulint* arr, dulint* aux_arr, ulint low, ulint high) -/*=========================================================*/ -{ - ut_ad(high <= 100000); - - UT_SORT_FUNCTION_BODY(sort_dulint, arr, aux_arr, low, high, - ut_dulint_cmp); -} - -/********************************************************************* -Tests for sorting. */ - -void -test3(void) -/*=======*/ -{ - ulint i, j; - ulint tm, oldtm; - - printf("-------------------------------------------\n"); - printf("TEST 3. Test of sorting \n"); - - for (i = 0; i < 100000; i++) { - uarr[i] = ut_rnd_gen_ulint(); - } - - oldtm = ut_clock(); - - for (j = 0; j < 1; j++) { - i = 100000; - - sort_ulint(uarr, aux_uarr, 0, i); - } - - tm = ut_clock(); - - printf("Wall clock time for sort of %lu ulints %lu millisecs\n", - j * i, tm - oldtm); - - for (i = 1; i < 100000; i++) { - ut_a(uarr[i - 1] < uarr[i]); - } - - for (i = 0; i < 100000; i++) { - uarr[i] = 99999 - i; - } - - sort_ulint(uarr, aux_uarr, 0, 100000); - - for (i = 1; i < 100000; i++) { - ut_a(uarr[i] == i); - } - - sort_ulint(uarr, aux_uarr, 0, 100000); - - for (i = 1; i < 100000; i++) { - ut_a(uarr[i] == i); - } - - sort_ulint(uarr, aux_uarr, 5, 6); - - for (i = 1; i < 100000; i++) { - ut_a(uarr[i] == i); - } - - for (i = 0; i < 100000; i++) { - uarr[i] = 5; - } - - sort_ulint(uarr, aux_uarr, 0, 100000); - - for (i = 1; i < 100000; i++) { - ut_a(uarr[i] == 5); - } - - for (i = 0; i < 100000; i++) { - duarr[i] = ut_dulint_create(ut_rnd_gen_ulint() & 0xFFFFFFFF, - ut_rnd_gen_ulint() & 0xFFFFFFFF); - } - - oldtm = ut_clock(); - - i = 100000; - - sort_dulint(duarr, aux_duarr, 0, i); - - tm = ut_clock(); - - printf("Wall clock time for sort of %lu dulints %lu millisecs\n", - j * i, tm - oldtm); - - for (i = 1; i < 100000; i++) { - ut_a(ut_dulint_cmp(duarr[i - 1], duarr[i]) < 0); - } - -} - -void -main(void) -{ - test1(); - test2(); - test3(); - - printf("TEST SUCCESSFULLY COMPLETED!\n"); -} |