mirror of
https://github.com/MariaDB/server.git
synced 2025-03-07 11:43:08 +01:00

storage/bdb/LICENSE: Import db-4.3.28 storage/bdb/btree/bt_compare.c: Import db-4.3.28 storage/bdb/btree/bt_conv.c: Import db-4.3.28 storage/bdb/btree/bt_curadj.c: Import db-4.3.28 storage/bdb/btree/bt_cursor.c: Import db-4.3.28 storage/bdb/btree/bt_delete.c: Import db-4.3.28 storage/bdb/btree/bt_method.c: Import db-4.3.28 storage/bdb/btree/bt_open.c: Import db-4.3.28 storage/bdb/btree/bt_put.c: Import db-4.3.28 storage/bdb/btree/bt_rec.c: Import db-4.3.28 storage/bdb/btree/bt_reclaim.c: Import db-4.3.28 storage/bdb/btree/bt_recno.c: Import db-4.3.28 storage/bdb/btree/bt_rsearch.c: Import db-4.3.28 storage/bdb/btree/bt_search.c: Import db-4.3.28 storage/bdb/btree/bt_split.c: Import db-4.3.28 storage/bdb/btree/bt_stat.c: Import db-4.3.28 storage/bdb/btree/bt_upgrade.c: Import db-4.3.28 storage/bdb/btree/bt_verify.c: Import db-4.3.28 storage/bdb/btree/btree.src: Import db-4.3.28 storage/bdb/build_win32/Berkeley_DB.dsw: Import db-4.3.28 storage/bdb/build_win32/app_dsp.src: Import db-4.3.28 storage/bdb/build_win32/db_test.src: Import db-4.3.28 storage/bdb/build_win32/dbkill.cpp: Import db-4.3.28 storage/bdb/build_win32/dynamic_dsp.src: Import db-4.3.28 storage/bdb/build_win32/java_dsp.src: Import db-4.3.28 storage/bdb/build_win32/libdb_tcl.def: Import db-4.3.28 storage/bdb/build_win32/libdbrc.src: Import db-4.3.28 storage/bdb/build_win32/static_dsp.src: Import db-4.3.28 storage/bdb/build_win32/tcl_dsp.src: Import db-4.3.28 storage/bdb/clib/getcwd.c: Import db-4.3.28 storage/bdb/clib/getopt.c: Import db-4.3.28 storage/bdb/clib/memcmp.c: Import db-4.3.28 storage/bdb/clib/memmove.c: Import db-4.3.28 storage/bdb/clib/raise.c: Import db-4.3.28 storage/bdb/clib/snprintf.c: Import db-4.3.28 storage/bdb/clib/strcasecmp.c: Import db-4.3.28 storage/bdb/clib/strdup.c: Import db-4.3.28 storage/bdb/clib/strerror.c: Import db-4.3.28 storage/bdb/common/db_byteorder.c: Import db-4.3.28 storage/bdb/common/db_err.c: Import db-4.3.28 storage/bdb/common/db_getlong.c: Import db-4.3.28 storage/bdb/common/db_idspace.c: Import db-4.3.28 storage/bdb/common/db_log2.c: Import db-4.3.28 storage/bdb/common/util_arg.c: Import db-4.3.28 storage/bdb/common/util_cache.c: Import db-4.3.28 storage/bdb/common/util_log.c: Import db-4.3.28 storage/bdb/common/util_sig.c: Import db-4.3.28 storage/bdb/cxx/cxx_db.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_dbc.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_dbt.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_env.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_except.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_lock.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_logc.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_mpool.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_txn.cpp: Import db-4.3.28 storage/bdb/db/crdel.src: Import db-4.3.28 storage/bdb/db/crdel_rec.c: Import db-4.3.28 storage/bdb/db/db.c: Import db-4.3.28 storage/bdb/db/db.src: Import db-4.3.28 storage/bdb/db/db_am.c: Import db-4.3.28 storage/bdb/db/db_cam.c: Import db-4.3.28 storage/bdb/db/db_conv.c: Import db-4.3.28 storage/bdb/db/db_dispatch.c: Import db-4.3.28 storage/bdb/db/db_dup.c: Import db-4.3.28 storage/bdb/db/db_iface.c: Import db-4.3.28 storage/bdb/db/db_join.c: Import db-4.3.28 storage/bdb/db/db_meta.c: Import db-4.3.28 storage/bdb/db/db_method.c: Import db-4.3.28 storage/bdb/db/db_open.c: Import db-4.3.28 storage/bdb/db/db_overflow.c: Import db-4.3.28 storage/bdb/db/db_pr.c: Import db-4.3.28 storage/bdb/db/db_rec.c: Import db-4.3.28 storage/bdb/db/db_reclaim.c: Import db-4.3.28 storage/bdb/db/db_remove.c: Import db-4.3.28 storage/bdb/db/db_rename.c: Import db-4.3.28 storage/bdb/db/db_ret.c: Import db-4.3.28 storage/bdb/db/db_truncate.c: Import db-4.3.28 storage/bdb/db/db_upg.c: Import db-4.3.28 storage/bdb/db/db_upg_opd.c: Import db-4.3.28 storage/bdb/db/db_vrfy.c: Import db-4.3.28 storage/bdb/db/db_vrfyutil.c: Import db-4.3.28 storage/bdb/db185/db185.c: Import db-4.3.28 storage/bdb/db185/db185_int.in: Import db-4.3.28 storage/bdb/db_archive/db_archive.c: Import db-4.3.28 storage/bdb/db_checkpoint/db_checkpoint.c: Import db-4.3.28 storage/bdb/db_deadlock/db_deadlock.c: Import db-4.3.28 storage/bdb/db_dump/db_dump.c: Import db-4.3.28 storage/bdb/db_dump185/db_dump185.c: Import db-4.3.28 storage/bdb/db_load/db_load.c: Import db-4.3.28 storage/bdb/db_printlog/README: Import db-4.3.28 storage/bdb/db_printlog/db_printlog.c: Import db-4.3.28 storage/bdb/db_printlog/dbname.awk: Import db-4.3.28 storage/bdb/db_printlog/rectype.awk: Import db-4.3.28 storage/bdb/db_printlog/status.awk: Import db-4.3.28 storage/bdb/db_recover/db_recover.c: Import db-4.3.28 storage/bdb/db_stat/db_stat.c: Import db-4.3.28 storage/bdb/db_upgrade/db_upgrade.c: Import db-4.3.28 storage/bdb/db_verify/db_verify.c: Import db-4.3.28 storage/bdb/dbinc/btree.h: Import db-4.3.28 storage/bdb/dbinc/crypto.h: Import db-4.3.28 storage/bdb/dbinc/cxx_int.h: Import db-4.3.28 storage/bdb/dbinc/db.in: Import db-4.3.28 storage/bdb/dbinc/db_185.in: Import db-4.3.28 storage/bdb/dbinc/db_am.h: Import db-4.3.28 storage/bdb/dbinc/db_cxx.in: Import db-4.3.28 storage/bdb/dbinc/db_dispatch.h: Import db-4.3.28 storage/bdb/dbinc/db_int.in: Import db-4.3.28 storage/bdb/dbinc/db_join.h: Import db-4.3.28 storage/bdb/dbinc/db_page.h: Import db-4.3.28 storage/bdb/dbinc/db_server_int.h: Import db-4.3.28 storage/bdb/dbinc/db_shash.h: Import db-4.3.28 storage/bdb/dbinc/db_swap.h: Import db-4.3.28 storage/bdb/dbinc/db_upgrade.h: Import db-4.3.28 storage/bdb/dbinc/db_verify.h: Import db-4.3.28 storage/bdb/dbinc/debug.h: Import db-4.3.28 storage/bdb/dbinc/fop.h: Import db-4.3.28 storage/bdb/dbinc/globals.h: Import db-4.3.28 storage/bdb/dbinc/hash.h: Import db-4.3.28 storage/bdb/dbinc/hmac.h: Import db-4.3.28 storage/bdb/dbinc/lock.h: Import db-4.3.28 storage/bdb/dbinc/log.h: Import db-4.3.28 storage/bdb/dbinc/mp.h: Import db-4.3.28 storage/bdb/dbinc/mutex.h: Import db-4.3.28 storage/bdb/dbinc/os.h: Import db-4.3.28 storage/bdb/dbinc/qam.h: Import db-4.3.28 storage/bdb/dbinc/queue.h: Import db-4.3.28 storage/bdb/dbinc/region.h: Import db-4.3.28 storage/bdb/dbinc/rep.h: Import db-4.3.28 storage/bdb/dbinc/shqueue.h: Import db-4.3.28 storage/bdb/dbinc/tcl_db.h: Import db-4.3.28 storage/bdb/dbinc/txn.h: Import db-4.3.28 storage/bdb/dbinc/xa.h: Import db-4.3.28 storage/bdb/dbm/dbm.c: Import db-4.3.28 storage/bdb/dbreg/dbreg.c: Import db-4.3.28 storage/bdb/dbreg/dbreg.src: Import db-4.3.28 storage/bdb/dbreg/dbreg_rec.c: Import db-4.3.28 storage/bdb/dbreg/dbreg_util.c: Import db-4.3.28 storage/bdb/dist/Makefile.in: Import db-4.3.28 storage/bdb/dist/RELEASE: Import db-4.3.28 storage/bdb/dist/aclocal/config.ac: Import db-4.3.28 storage/bdb/dist/aclocal/libtool.ac: Import db-4.3.28 storage/bdb/dist/aclocal/mutex.ac: Import db-4.3.28 storage/bdb/dist/aclocal/options.ac: Import db-4.3.28 storage/bdb/dist/aclocal/programs.ac: Import db-4.3.28 storage/bdb/dist/aclocal/sosuffix.ac: Import db-4.3.28 storage/bdb/dist/aclocal/tcl.ac: Import db-4.3.28 storage/bdb/dist/aclocal/types.ac: Import db-4.3.28 storage/bdb/dist/aclocal_java/ac_jni_include_dirs.ac: Import db-4.3.28 storage/bdb/dist/aclocal_java/ac_prog_java.ac: Import db-4.3.28 storage/bdb/dist/buildrel: Import db-4.3.28 storage/bdb/dist/configure.ac: Import db-4.3.28 storage/bdb/dist/gen_inc.awk: Import db-4.3.28 storage/bdb/dist/gen_rec.awk: Import db-4.3.28 storage/bdb/dist/gen_rpc.awk: Import db-4.3.28 storage/bdb/dist/ltmain.sh: Import db-4.3.28 storage/bdb/dist/pubdef.in: Import db-4.3.28 storage/bdb/dist/srcfiles.in: Import db-4.3.28 storage/bdb/dist/vx_2.0/BerkeleyDB.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.0/wpj.in: Import db-4.3.28 storage/bdb/dist/vx_config.in: Import db-4.3.28 storage/bdb/dist/vx_setup/CONFIG.in: Import db-4.3.28 storage/bdb/dist/vx_setup/LICENSE.TXT: Import db-4.3.28 storage/bdb/dist/vx_setup/vx_allfile.in: Import db-4.3.28 storage/bdb/dist/vx_setup/vx_demofile.in: Import db-4.3.28 storage/bdb/dist/win_config.in: Import db-4.3.28 storage/bdb/dist/win_exports.in: Import db-4.3.28 storage/bdb/env/db_salloc.c: Import db-4.3.28 storage/bdb/env/db_shash.c: Import db-4.3.28 storage/bdb/env/env_file.c: Import db-4.3.28 storage/bdb/env/env_method.c: Import db-4.3.28 storage/bdb/env/env_open.c: Import db-4.3.28 storage/bdb/env/env_recover.c: Import db-4.3.28 storage/bdb/env/env_region.c: Import db-4.3.28 storage/bdb/fileops/fileops.src: Import db-4.3.28 storage/bdb/fileops/fop_basic.c: Import db-4.3.28 storage/bdb/fileops/fop_rec.c: Import db-4.3.28 storage/bdb/fileops/fop_util.c: Import db-4.3.28 storage/bdb/hash/hash.c: Import db-4.3.28 storage/bdb/hash/hash.src: Import db-4.3.28 storage/bdb/hash/hash_conv.c: Import db-4.3.28 storage/bdb/hash/hash_dup.c: Import db-4.3.28 storage/bdb/hash/hash_func.c: Import db-4.3.28 storage/bdb/hash/hash_meta.c: Import db-4.3.28 storage/bdb/hash/hash_method.c: Import db-4.3.28 storage/bdb/hash/hash_open.c: Import db-4.3.28 storage/bdb/hash/hash_page.c: Import db-4.3.28 storage/bdb/hash/hash_rec.c: Import db-4.3.28 storage/bdb/hash/hash_reclaim.c: Import db-4.3.28 storage/bdb/hash/hash_stat.c: Import db-4.3.28 storage/bdb/hash/hash_upgrade.c: Import db-4.3.28 storage/bdb/hash/hash_verify.c: Import db-4.3.28 storage/bdb/hmac/hmac.c: Import db-4.3.28 storage/bdb/hmac/sha1.c: Import db-4.3.28 storage/bdb/hsearch/hsearch.c: Import db-4.3.28 storage/bdb/lock/lock.c: Import db-4.3.28 storage/bdb/lock/lock_deadlock.c: Import db-4.3.28 storage/bdb/lock/lock_method.c: Import db-4.3.28 storage/bdb/lock/lock_region.c: Import db-4.3.28 storage/bdb/lock/lock_stat.c: Import db-4.3.28 storage/bdb/lock/lock_util.c: Import db-4.3.28 storage/bdb/log/log.c: Import db-4.3.28 storage/bdb/log/log_archive.c: Import db-4.3.28 storage/bdb/log/log_compare.c: Import db-4.3.28 storage/bdb/log/log_get.c: Import db-4.3.28 storage/bdb/log/log_method.c: Import db-4.3.28 storage/bdb/log/log_put.c: Import db-4.3.28 storage/bdb/mp/mp_alloc.c: Import db-4.3.28 storage/bdb/mp/mp_bh.c: Import db-4.3.28 storage/bdb/mp/mp_fget.c: Import db-4.3.28 storage/bdb/mp/mp_fopen.c: Import db-4.3.28 storage/bdb/mp/mp_fput.c: Import db-4.3.28 storage/bdb/mp/mp_fset.c: Import db-4.3.28 storage/bdb/mp/mp_method.c: Import db-4.3.28 storage/bdb/mp/mp_region.c: Import db-4.3.28 storage/bdb/mp/mp_register.c: Import db-4.3.28 storage/bdb/mp/mp_stat.c: Import db-4.3.28 storage/bdb/mp/mp_sync.c: Import db-4.3.28 storage/bdb/mp/mp_trickle.c: Import db-4.3.28 storage/bdb/mutex/mut_fcntl.c: Import db-4.3.28 storage/bdb/mutex/mut_pthread.c: Import db-4.3.28 storage/bdb/mutex/mut_tas.c: Import db-4.3.28 storage/bdb/mutex/mut_win32.c: Import db-4.3.28 storage/bdb/mutex/mutex.c: Import db-4.3.28 storage/bdb/mutex/tm.c: Import db-4.3.28 storage/bdb/mutex/uts4_cc.s: Import db-4.3.28 storage/bdb/os/os_abs.c: Import db-4.3.28 storage/bdb/os/os_alloc.c: Import db-4.3.28 storage/bdb/os/os_clock.c: Import db-4.3.28 storage/bdb/os/os_config.c: Import db-4.3.28 storage/bdb/os/os_dir.c: Import db-4.3.28 storage/bdb/os/os_errno.c: Import db-4.3.28 storage/bdb/os/os_fid.c: Import db-4.3.28 storage/bdb/os/os_fsync.c: Import db-4.3.28 storage/bdb/os/os_handle.c: Import db-4.3.28 storage/bdb/os/os_id.c: Import db-4.3.28 storage/bdb/os/os_map.c: Import db-4.3.28 storage/bdb/os/os_method.c: Import db-4.3.28 storage/bdb/os/os_oflags.c: Import db-4.3.28 storage/bdb/os/os_open.c: Import db-4.3.28 storage/bdb/os/os_region.c: Import db-4.3.28 storage/bdb/os/os_rename.c: Import db-4.3.28 storage/bdb/os/os_root.c: Import db-4.3.28 storage/bdb/os/os_rpath.c: Import db-4.3.28 storage/bdb/os/os_rw.c: Import db-4.3.28 storage/bdb/os/os_seek.c: Import db-4.3.28 storage/bdb/os/os_sleep.c: Import db-4.3.28 storage/bdb/os/os_spin.c: Import db-4.3.28 storage/bdb/os/os_stat.c: Import db-4.3.28 storage/bdb/os/os_tmpdir.c: Import db-4.3.28 storage/bdb/os/os_unlink.c: Import db-4.3.28 storage/bdb/os_vxworks/os_vx_abs.c: Import db-4.3.28 storage/bdb/os_vxworks/os_vx_config.c: Import db-4.3.28 storage/bdb/os_vxworks/os_vx_map.c: Import db-4.3.28 storage/bdb/os_win32/os_abs.c: Import db-4.3.28 storage/bdb/os_win32/os_clock.c: Import db-4.3.28 storage/bdb/os_win32/os_config.c: Import db-4.3.28 storage/bdb/os_win32/os_dir.c: Import db-4.3.28 storage/bdb/os_win32/os_errno.c: Import db-4.3.28 storage/bdb/os_win32/os_fid.c: Import db-4.3.28 storage/bdb/os_win32/os_fsync.c: Import db-4.3.28 storage/bdb/os_win32/os_handle.c: Import db-4.3.28 storage/bdb/os_win32/os_map.c: Import db-4.3.28 storage/bdb/os_win32/os_open.c: Import db-4.3.28 storage/bdb/os_win32/os_rename.c: Import db-4.3.28 storage/bdb/os_win32/os_rw.c: Import db-4.3.28 storage/bdb/os_win32/os_seek.c: Import db-4.3.28 storage/bdb/os_win32/os_sleep.c: Import db-4.3.28 storage/bdb/os_win32/os_spin.c: Import db-4.3.28 storage/bdb/os_win32/os_stat.c: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.pm: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.pod.P: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.pod: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.xs: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/Changes: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/MANIFEST: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/Makefile.PL: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/README: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/config.in: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/constants.h: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/mkconsts: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/patches/5.004: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/ppport.h: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/scan: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/btree.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/destroy.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/env.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/filter.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/hash.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/join.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/mldbm.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/queue.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/recno.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/strict.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/subdb.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/txn.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/util.pm: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/typemap: Import db-4.3.28 storage/bdb/perl/DB_File/Changes: Import db-4.3.28 storage/bdb/perl/DB_File/DB_File.pm: Import db-4.3.28 storage/bdb/perl/DB_File/DB_File.xs: Import db-4.3.28 storage/bdb/perl/DB_File/MANIFEST: Import db-4.3.28 storage/bdb/perl/DB_File/Makefile.PL: Import db-4.3.28 storage/bdb/perl/DB_File/README: Import db-4.3.28 storage/bdb/perl/DB_File/dbinfo: Import db-4.3.28 storage/bdb/perl/DB_File/patches/5.004: Import db-4.3.28 storage/bdb/perl/DB_File/ppport.h: Import db-4.3.28 storage/bdb/perl/DB_File/t/db-btree.t: Import db-4.3.28 storage/bdb/perl/DB_File/t/db-hash.t: Import db-4.3.28 storage/bdb/perl/DB_File/t/db-recno.t: Import db-4.3.28 storage/bdb/perl/DB_File/typemap: Import db-4.3.28 storage/bdb/qam/qam.c: Import db-4.3.28 storage/bdb/qam/qam.src: Import db-4.3.28 storage/bdb/qam/qam_conv.c: Import db-4.3.28 storage/bdb/qam/qam_files.c: Import db-4.3.28 storage/bdb/qam/qam_method.c: Import db-4.3.28 storage/bdb/qam/qam_open.c: Import db-4.3.28 storage/bdb/qam/qam_rec.c: Import db-4.3.28 storage/bdb/qam/qam_stat.c: Import db-4.3.28 storage/bdb/qam/qam_upgrade.c: Import db-4.3.28 storage/bdb/qam/qam_verify.c: Import db-4.3.28 storage/bdb/rep/rep_method.c: Import db-4.3.28 storage/bdb/rep/rep_record.c: Import db-4.3.28 storage/bdb/rep/rep_region.c: Import db-4.3.28 storage/bdb/rep/rep_util.c: Import db-4.3.28 storage/bdb/rpc_client/client.c: Import db-4.3.28 storage/bdb/rpc_client/gen_client_ret.c: Import db-4.3.28 storage/bdb/rpc_server/c/db_server_util.c: Import db-4.3.28 storage/bdb/rpc_server/cxx/db_server_cxxproc.cpp: Import db-4.3.28 storage/bdb/rpc_server/cxx/db_server_cxxutil.cpp: Import db-4.3.28 storage/bdb/rpc_server/java/FreeList.java: Import db-4.3.28 storage/bdb/rpc_server/java/LocalIterator.java: Import db-4.3.28 storage/bdb/rpc_server/java/README: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDb.java: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDbEnv.java: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDbTxn.java: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDbc.java: Import db-4.3.28 storage/bdb/rpc_server/java/Timer.java: Import db-4.3.28 storage/bdb/rpc_server/java/gen/__db_open_reply.java: Import db-4.3.28 storage/bdb/rpc_server/java/gen/__db_stat_msg.java: Import db-4.3.28 storage/bdb/rpc_server/java/gen/db_server.java: Import db-4.3.28 storage/bdb/rpc_server/java/s_jrpcgen: Import db-4.3.28 storage/bdb/rpc_server/rpc.src: Import db-4.3.28 storage/bdb/tcl/docs/db.html: Import db-4.3.28 storage/bdb/tcl/docs/env.html: Import db-4.3.28 storage/bdb/tcl/docs/historic.html: Import db-4.3.28 storage/bdb/tcl/docs/index.html: Import db-4.3.28 storage/bdb/tcl/docs/library.html: Import db-4.3.28 storage/bdb/tcl/docs/lock.html: Import db-4.3.28 storage/bdb/tcl/docs/log.html: Import db-4.3.28 storage/bdb/tcl/docs/mpool.html: Import db-4.3.28 storage/bdb/tcl/docs/rep.html: Import db-4.3.28 storage/bdb/tcl/docs/test.html: Import db-4.3.28 storage/bdb/tcl/docs/txn.html: Import db-4.3.28 storage/bdb/tcl/tcl_compat.c: Import db-4.3.28 storage/bdb/tcl/tcl_db.c: Import db-4.3.28 storage/bdb/tcl/tcl_db_pkg.c: Import db-4.3.28 storage/bdb/tcl/tcl_dbcursor.c: Import db-4.3.28 storage/bdb/tcl/tcl_env.c: Import db-4.3.28 storage/bdb/tcl/tcl_internal.c: Import db-4.3.28 storage/bdb/tcl/tcl_lock.c: Import db-4.3.28 storage/bdb/tcl/tcl_log.c: Import db-4.3.28 storage/bdb/tcl/tcl_mp.c: Import db-4.3.28 storage/bdb/tcl/tcl_rep.c: Import db-4.3.28 storage/bdb/tcl/tcl_txn.c: Import db-4.3.28 storage/bdb/tcl/tcl_util.c: Import db-4.3.28 storage/bdb/test/archive.tcl: Import db-4.3.28 storage/bdb/test/bigfile001.tcl: Import db-4.3.28 storage/bdb/test/bigfile002.tcl: Import db-4.3.28 storage/bdb/test/byteorder.tcl: Import db-4.3.28 storage/bdb/test/conscript.tcl: Import db-4.3.28 storage/bdb/test/dbm.tcl: Import db-4.3.28 storage/bdb/test/dbscript.tcl: Import db-4.3.28 storage/bdb/test/ddoyscript.tcl: Import db-4.3.28 storage/bdb/test/ddscript.tcl: Import db-4.3.28 storage/bdb/test/dead001.tcl: Import db-4.3.28 storage/bdb/test/dead002.tcl: Import db-4.3.28 storage/bdb/test/dead003.tcl: Import db-4.3.28 storage/bdb/test/dead004.tcl: Import db-4.3.28 storage/bdb/test/dead005.tcl: Import db-4.3.28 storage/bdb/test/dead006.tcl: Import db-4.3.28 storage/bdb/test/dead007.tcl: Import db-4.3.28 storage/bdb/test/env001.tcl: Import db-4.3.28 storage/bdb/test/env002.tcl: Import db-4.3.28 storage/bdb/test/env003.tcl: Import db-4.3.28 storage/bdb/test/env004.tcl: Import db-4.3.28 storage/bdb/test/env005.tcl: Import db-4.3.28 storage/bdb/test/env006.tcl: Import db-4.3.28 storage/bdb/test/env007.tcl: Import db-4.3.28 storage/bdb/test/env008.tcl: Import db-4.3.28 storage/bdb/test/env009.tcl: Import db-4.3.28 storage/bdb/test/env010.tcl: Import db-4.3.28 storage/bdb/test/env011.tcl: Import db-4.3.28 storage/bdb/test/hsearch.tcl: Import db-4.3.28 storage/bdb/test/join.tcl: Import db-4.3.28 storage/bdb/test/lock001.tcl: Import db-4.3.28 storage/bdb/test/lock002.tcl: Import db-4.3.28 storage/bdb/test/lock003.tcl: Import db-4.3.28 storage/bdb/test/lock004.tcl: Import db-4.3.28 storage/bdb/test/lock005.tcl: Import db-4.3.28 storage/bdb/test/lockscript.tcl: Import db-4.3.28 storage/bdb/test/log001.tcl: Import db-4.3.28 storage/bdb/test/log002.tcl: Import db-4.3.28 storage/bdb/test/log003.tcl: Import db-4.3.28 storage/bdb/test/log004.tcl: Import db-4.3.28 storage/bdb/test/log005.tcl: Import db-4.3.28 storage/bdb/test/logtrack.tcl: Import db-4.3.28 storage/bdb/test/mdbscript.tcl: Import db-4.3.28 storage/bdb/test/memp001.tcl: Import db-4.3.28 storage/bdb/test/memp002.tcl: Import db-4.3.28 storage/bdb/test/memp003.tcl: Import db-4.3.28 storage/bdb/test/mpoolscript.tcl: Import db-4.3.28 storage/bdb/test/mutex001.tcl: Import db-4.3.28 storage/bdb/test/mutex002.tcl: Import db-4.3.28 storage/bdb/test/mutex003.tcl: Import db-4.3.28 storage/bdb/test/mutexscript.tcl: Import db-4.3.28 storage/bdb/test/ndbm.tcl: Import db-4.3.28 storage/bdb/test/parallel.tcl: Import db-4.3.28 storage/bdb/test/recd001.tcl: Import db-4.3.28 storage/bdb/test/recd002.tcl: Import db-4.3.28 storage/bdb/test/recd003.tcl: Import db-4.3.28 storage/bdb/test/recd004.tcl: Import db-4.3.28 storage/bdb/test/recd005.tcl: Import db-4.3.28 storage/bdb/test/recd006.tcl: Import db-4.3.28 storage/bdb/test/recd007.tcl: Import db-4.3.28 storage/bdb/test/recd008.tcl: Import db-4.3.28 storage/bdb/test/recd009.tcl: Import db-4.3.28 storage/bdb/test/recd010.tcl: Import db-4.3.28 storage/bdb/test/recd011.tcl: Import db-4.3.28 storage/bdb/test/recd012.tcl: Import db-4.3.28 storage/bdb/test/recd013.tcl: Import db-4.3.28 storage/bdb/test/recd014.tcl: Import db-4.3.28 storage/bdb/test/recd015.tcl: Import db-4.3.28 storage/bdb/test/recd016.tcl: Import db-4.3.28 storage/bdb/test/recd017.tcl: Import db-4.3.28 storage/bdb/test/recd018.tcl: Import db-4.3.28 storage/bdb/test/recd019.tcl: Import db-4.3.28 storage/bdb/test/recd020.tcl: Import db-4.3.28 storage/bdb/test/recd15scr.tcl: Import db-4.3.28 storage/bdb/test/recdscript.tcl: Import db-4.3.28 storage/bdb/test/rep001.tcl: Import db-4.3.28 storage/bdb/test/rep002.tcl: Import db-4.3.28 storage/bdb/test/rep003.tcl: Import db-4.3.28 storage/bdb/test/rep005.tcl: Import db-4.3.28 storage/bdb/test/reputils.tcl: Import db-4.3.28 storage/bdb/test/rpc001.tcl: Import db-4.3.28 storage/bdb/test/rpc002.tcl: Import db-4.3.28 storage/bdb/test/rpc003.tcl: Import db-4.3.28 storage/bdb/test/rpc004.tcl: Import db-4.3.28 storage/bdb/test/rpc005.tcl: Import db-4.3.28 storage/bdb/test/rsrc001.tcl: Import db-4.3.28 storage/bdb/test/rsrc002.tcl: Import db-4.3.28 storage/bdb/test/rsrc003.tcl: Import db-4.3.28 storage/bdb/test/rsrc004.tcl: Import db-4.3.28 storage/bdb/test/scr001/chk.code: Import db-4.3.28 storage/bdb/test/scr003/chk.define: Import db-4.3.28 storage/bdb/test/scr004/chk.javafiles: Import db-4.3.28 storage/bdb/test/scr005/chk.nl: Import db-4.3.28 storage/bdb/test/scr006/chk.offt: Import db-4.3.28 storage/bdb/test/scr007/chk.proto: Import db-4.3.28 storage/bdb/test/scr008/chk.pubdef: Import db-4.3.28 storage/bdb/test/scr009/chk.srcfiles: Import db-4.3.28 storage/bdb/test/scr010/chk.str: Import db-4.3.28 storage/bdb/test/scr010/spell.ok: Import db-4.3.28 storage/bdb/test/scr011/chk.tags: Import db-4.3.28 storage/bdb/test/scr012/chk.vx_code: Import db-4.3.28 storage/bdb/test/scr013/chk.stats: Import db-4.3.28 storage/bdb/test/scr015/TestConstruct01.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestConstruct01.testerr: Import db-4.3.28 storage/bdb/test/scr015/TestGetSetMethods.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestKeyRange.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestLogc.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestSimpleAccess.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestTruncate.cpp: Import db-4.3.28 storage/bdb/test/scr015/chk.cxxtests: Import db-4.3.28 storage/bdb/test/scr016/CallbackTest.java: Import db-4.3.28 storage/bdb/test/scr016/CallbackTest.testout: Import db-4.3.28 storage/bdb/test/scr016/TestAppendRecno.java: Import db-4.3.28 storage/bdb/test/scr016/TestAssociate.java: Import db-4.3.28 storage/bdb/test/scr016/TestClosedDb.java: Import db-4.3.28 storage/bdb/test/scr016/TestClosedDb.testout: Import db-4.3.28 storage/bdb/test/scr016/TestConstruct01.java: Import db-4.3.28 storage/bdb/test/scr016/TestConstruct01.testout: Import db-4.3.28 storage/bdb/test/scr016/TestConstruct02.java: Import db-4.3.28 storage/bdb/test/scr016/TestDbtFlags.java: Import db-4.3.28 storage/bdb/test/scr016/TestGetSetMethods.java: Import db-4.3.28 storage/bdb/test/scr016/TestKeyRange.java: Import db-4.3.28 storage/bdb/test/scr016/TestLockVec.java: Import db-4.3.28 storage/bdb/test/scr016/TestLogc.java: Import db-4.3.28 storage/bdb/test/scr016/TestOpenEmpty.java: Import db-4.3.28 storage/bdb/test/scr016/TestOpenEmpty.testerr: Import db-4.3.28 storage/bdb/test/scr016/TestReplication.java: Import db-4.3.28 storage/bdb/test/scr016/TestRpcServer.java: Import db-4.3.28 storage/bdb/test/scr016/TestSameDbt.java: Import db-4.3.28 storage/bdb/test/scr016/TestSimpleAccess.java: Import db-4.3.28 storage/bdb/test/scr016/TestStat.java: Import db-4.3.28 storage/bdb/test/scr016/TestStat.testout: Import db-4.3.28 storage/bdb/test/scr016/TestTruncate.java: Import db-4.3.28 storage/bdb/test/scr016/TestTruncate.testout: Import db-4.3.28 storage/bdb/test/scr016/TestUtil.java: Import db-4.3.28 storage/bdb/test/scr016/TestXAServlet.java: Import db-4.3.28 storage/bdb/test/scr016/chk.javatests: Import db-4.3.28 storage/bdb/test/scr016/ignore: Import db-4.3.28 storage/bdb/test/scr016/testone: Import db-4.3.28 storage/bdb/test/scr017/chk.db185: Import db-4.3.28 storage/bdb/test/scr019/chk.include: Import db-4.3.28 storage/bdb/test/scr020/chk.inc: Import db-4.3.28 storage/bdb/test/scr021/chk.flags: Import db-4.3.28 storage/bdb/test/scr022/chk.rr: Import db-4.3.28 storage/bdb/test/sdb001.tcl: Import db-4.3.28 storage/bdb/test/sdb002.tcl: Import db-4.3.28 storage/bdb/test/sdb003.tcl: Import db-4.3.28 storage/bdb/test/sdb004.tcl: Import db-4.3.28 storage/bdb/test/sdb005.tcl: Import db-4.3.28 storage/bdb/test/sdb006.tcl: Import db-4.3.28 storage/bdb/test/sdb007.tcl: Import db-4.3.28 storage/bdb/test/sdb008.tcl: Import db-4.3.28 storage/bdb/test/sdb009.tcl: Import db-4.3.28 storage/bdb/test/sdb010.tcl: Import db-4.3.28 storage/bdb/test/sdb011.tcl: Import db-4.3.28 storage/bdb/test/sdb012.tcl: Import db-4.3.28 storage/bdb/test/sdbscript.tcl: Import db-4.3.28 storage/bdb/test/sdbtest001.tcl: Import db-4.3.28 storage/bdb/test/sdbtest002.tcl: Import db-4.3.28 storage/bdb/test/sdbutils.tcl: Import db-4.3.28 storage/bdb/test/sec001.tcl: Import db-4.3.28 storage/bdb/test/sec002.tcl: Import db-4.3.28 storage/bdb/test/shelltest.tcl: Import db-4.3.28 storage/bdb/test/si001.tcl: Import db-4.3.28 storage/bdb/test/si002.tcl: Import db-4.3.28 storage/bdb/test/si003.tcl: Import db-4.3.28 storage/bdb/test/si004.tcl: Import db-4.3.28 storage/bdb/test/si005.tcl: Import db-4.3.28 storage/bdb/test/sysscript.tcl: Import db-4.3.28 storage/bdb/test/test.tcl: Import db-4.3.28 storage/bdb/test/test001.tcl: Import db-4.3.28 storage/bdb/test/test002.tcl: Import db-4.3.28 storage/bdb/test/test003.tcl: Import db-4.3.28 storage/bdb/test/test004.tcl: Import db-4.3.28 storage/bdb/test/test005.tcl: Import db-4.3.28 storage/bdb/test/test006.tcl: Import db-4.3.28 storage/bdb/test/test007.tcl: Import db-4.3.28 storage/bdb/test/test008.tcl: Import db-4.3.28 storage/bdb/test/test009.tcl: Import db-4.3.28 storage/bdb/test/test010.tcl: Import db-4.3.28 storage/bdb/test/test011.tcl: Import db-4.3.28 storage/bdb/test/test012.tcl: Import db-4.3.28 storage/bdb/test/test013.tcl: Import db-4.3.28 storage/bdb/test/test014.tcl: Import db-4.3.28 storage/bdb/test/test015.tcl: Import db-4.3.28 storage/bdb/test/test016.tcl: Import db-4.3.28 storage/bdb/test/test017.tcl: Import db-4.3.28 storage/bdb/test/test018.tcl: Import db-4.3.28 storage/bdb/test/test019.tcl: Import db-4.3.28 storage/bdb/test/test020.tcl: Import db-4.3.28 storage/bdb/test/test021.tcl: Import db-4.3.28 storage/bdb/test/test022.tcl: Import db-4.3.28 storage/bdb/test/test023.tcl: Import db-4.3.28 storage/bdb/test/test024.tcl: Import db-4.3.28 storage/bdb/test/test025.tcl: Import db-4.3.28 storage/bdb/test/test026.tcl: Import db-4.3.28 storage/bdb/test/test027.tcl: Import db-4.3.28 storage/bdb/test/test028.tcl: Import db-4.3.28 storage/bdb/test/test029.tcl: Import db-4.3.28 storage/bdb/test/test030.tcl: Import db-4.3.28 storage/bdb/test/test031.tcl: Import db-4.3.28 storage/bdb/test/test032.tcl: Import db-4.3.28 storage/bdb/test/test033.tcl: Import db-4.3.28 storage/bdb/test/test034.tcl: Import db-4.3.28 storage/bdb/test/test035.tcl: Import db-4.3.28 storage/bdb/test/test036.tcl: Import db-4.3.28 storage/bdb/test/test037.tcl: Import db-4.3.28 storage/bdb/test/test038.tcl: Import db-4.3.28 storage/bdb/test/test039.tcl: Import db-4.3.28 storage/bdb/test/test040.tcl: Import db-4.3.28 storage/bdb/test/test041.tcl: Import db-4.3.28 storage/bdb/test/test042.tcl: Import db-4.3.28 storage/bdb/test/test043.tcl: Import db-4.3.28 storage/bdb/test/test044.tcl: Import db-4.3.28 storage/bdb/test/test045.tcl: Import db-4.3.28 storage/bdb/test/test046.tcl: Import db-4.3.28 storage/bdb/test/test047.tcl: Import db-4.3.28 storage/bdb/test/test048.tcl: Import db-4.3.28 storage/bdb/test/test049.tcl: Import db-4.3.28 storage/bdb/test/test050.tcl: Import db-4.3.28 storage/bdb/test/test051.tcl: Import db-4.3.28 storage/bdb/test/test052.tcl: Import db-4.3.28 storage/bdb/test/test053.tcl: Import db-4.3.28 storage/bdb/test/test054.tcl: Import db-4.3.28 storage/bdb/test/test055.tcl: Import db-4.3.28 storage/bdb/test/test056.tcl: Import db-4.3.28 storage/bdb/test/test057.tcl: Import db-4.3.28 storage/bdb/test/test058.tcl: Import db-4.3.28 storage/bdb/test/test059.tcl: Import db-4.3.28 storage/bdb/test/test060.tcl: Import db-4.3.28 storage/bdb/test/test061.tcl: Import db-4.3.28 storage/bdb/test/test062.tcl: Import db-4.3.28 storage/bdb/test/test063.tcl: Import db-4.3.28 storage/bdb/test/test064.tcl: Import db-4.3.28 storage/bdb/test/test065.tcl: Import db-4.3.28 storage/bdb/test/test066.tcl: Import db-4.3.28 storage/bdb/test/test067.tcl: Import db-4.3.28 storage/bdb/test/test068.tcl: Import db-4.3.28 storage/bdb/test/test069.tcl: Import db-4.3.28 storage/bdb/test/test070.tcl: Import db-4.3.28 storage/bdb/test/test071.tcl: Import db-4.3.28 storage/bdb/test/test072.tcl: Import db-4.3.28 storage/bdb/test/test073.tcl: Import db-4.3.28 storage/bdb/test/test074.tcl: Import db-4.3.28 storage/bdb/test/test076.tcl: Import db-4.3.28 storage/bdb/test/test077.tcl: Import db-4.3.28 storage/bdb/test/test078.tcl: Import db-4.3.28 storage/bdb/test/test079.tcl: Import db-4.3.28 storage/bdb/test/test081.tcl: Import db-4.3.28 storage/bdb/test/test082.tcl: Import db-4.3.28 storage/bdb/test/test083.tcl: Import db-4.3.28 storage/bdb/test/test084.tcl: Import db-4.3.28 storage/bdb/test/test085.tcl: Import db-4.3.28 storage/bdb/test/test086.tcl: Import db-4.3.28 storage/bdb/test/test087.tcl: Import db-4.3.28 storage/bdb/test/test088.tcl: Import db-4.3.28 storage/bdb/test/test089.tcl: Import db-4.3.28 storage/bdb/test/test090.tcl: Import db-4.3.28 storage/bdb/test/test091.tcl: Import db-4.3.28 storage/bdb/test/test092.tcl: Import db-4.3.28 storage/bdb/test/test093.tcl: Import db-4.3.28 storage/bdb/test/test094.tcl: Import db-4.3.28 storage/bdb/test/test095.tcl: Import db-4.3.28 storage/bdb/test/test096.tcl: Import db-4.3.28 storage/bdb/test/test097.tcl: Import db-4.3.28 storage/bdb/test/test098.tcl: Import db-4.3.28 storage/bdb/test/test099.tcl: Import db-4.3.28 storage/bdb/test/test100.tcl: Import db-4.3.28 storage/bdb/test/test101.tcl: Import db-4.3.28 storage/bdb/test/testparams.tcl: Import db-4.3.28 storage/bdb/test/testutils.tcl: Import db-4.3.28 storage/bdb/test/txn001.tcl: Import db-4.3.28 storage/bdb/test/txn002.tcl: Import db-4.3.28 storage/bdb/test/txn003.tcl: Import db-4.3.28 storage/bdb/test/txn004.tcl: Import db-4.3.28 storage/bdb/test/txn005.tcl: Import db-4.3.28 storage/bdb/test/txn006.tcl: Import db-4.3.28 storage/bdb/test/txn007.tcl: Import db-4.3.28 storage/bdb/test/txn008.tcl: Import db-4.3.28 storage/bdb/test/txn009.tcl: Import db-4.3.28 storage/bdb/test/txnscript.tcl: Import db-4.3.28 storage/bdb/test/update.tcl: Import db-4.3.28 storage/bdb/test/upgrade.tcl: Import db-4.3.28 storage/bdb/test/wrap.tcl: Import db-4.3.28 storage/bdb/txn/txn.c: Import db-4.3.28 storage/bdb/txn/txn.src: Import db-4.3.28 storage/bdb/txn/txn_method.c: Import db-4.3.28 storage/bdb/txn/txn_rec.c: Import db-4.3.28 storage/bdb/txn/txn_recover.c: Import db-4.3.28 storage/bdb/txn/txn_region.c: Import db-4.3.28 storage/bdb/txn/txn_stat.c: Import db-4.3.28 storage/bdb/txn/txn_util.c: Import db-4.3.28 storage/bdb/xa/xa.c: Import db-4.3.28 storage/bdb/xa/xa_db.c: Import db-4.3.28 storage/bdb/xa/xa_map.c: Import db-4.3.28 storage/bdb/clib/strtol.c: Import db-4.3.28 storage/bdb/clib/strtoul.c: Import db-4.3.28 storage/bdb/common/crypto_stub.c: Import db-4.3.28 storage/bdb/crypto/aes_method.c: Import db-4.3.28 storage/bdb/crypto/crypto.c: Import db-4.3.28 storage/bdb/crypto/crypto.html: Import db-4.3.28 storage/bdb/crypto/mersenne/mt19937db.c: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-alg-fst.c: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-alg-fst.h: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-api-fst.c: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-api-fst.h: Import db-4.3.28 storage/bdb/cxx/cxx_multi.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_seq.cpp: Import db-4.3.28 storage/bdb/db/db_ovfl_vrfy.c: Import db-4.3.28 storage/bdb/db/db_setid.c: Import db-4.3.28 storage/bdb/db/db_setlsn.c: Import db-4.3.28 storage/bdb/db/db_stati.c: Import db-4.3.28 storage/bdb/db/db_vrfy_stub.c: Import db-4.3.28 storage/bdb/db_stat/dd.sh: Import db-4.3.28 storage/bdb/dbreg/dbreg_stat.c: Import db-4.3.28 storage/bdb/dist/aclocal/rpc.ac: Import db-4.3.28 storage/bdb/dist/aclocal/sequence.ac: Import db-4.3.28 storage/bdb/dist/config.hin: Import db-4.3.28 storage/bdb/dist/s_java_const: Import db-4.3.28 storage/bdb/dist/s_java_stat: Import db-4.3.28 storage/bdb/dist/s_java_swig: Import db-4.3.28 storage/bdb/dist/s_je2db: Import db-4.3.28 storage/bdb/dist/s_winmsi: Import db-4.3.28 storage/bdb/dist/template/db_server_proc: Import db-4.3.28 storage/bdb/dist/template/gen_client_ret: Import db-4.3.28 storage/bdb/dist/template/rec_btree: Import db-4.3.28 storage/bdb/dist/template/rec_crdel: Import db-4.3.28 storage/bdb/dist/template/rec_dbreg: Import db-4.3.28 storage/bdb/dist/template/rec_db: Import db-4.3.28 storage/bdb/dist/template/rec_fileops: Import db-4.3.28 storage/bdb/dist/template/rec_hash: Import db-4.3.28 storage/bdb/dist/template/rec_qam: Import db-4.3.28 storage/bdb/dist/template/rec_rep: Import db-4.3.28 storage/bdb/dist/template/rec_txn: Import db-4.3.28 storage/bdb/dist/vx_2.0/BerkeleyDBsmall.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.2/BerkeleyDB.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.2/BerkeleyDBsmall.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.2/wpj.in: Import db-4.3.28 storage/bdb/dist/win_db.in: Import db-4.3.28 storage/bdb/dist/winmsi/dbcorewix.in: Import db-4.3.28 storage/bdb/dist/winmsi/dbvarsbat.in: Import db-4.3.28 storage/bdb/dist/winmsi/dbwix.m4: Import db-4.3.28 storage/bdb/dist/winmsi/environment.in: Import db-4.3.28 storage/bdb/dist/winmsi/features.in: Import db-4.3.28 storage/bdb/dist/winmsi/files.in: Import db-4.3.28 storage/bdb/dist/winmsi/images/caticon.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/foldernew.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/folderup.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/sleepycat.jpg: Import db-4.3.28 storage/bdb/dist/winmsi/images/topstripe.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/webicon.ico: Import db-4.3.28 storage/bdb/dist/winmsi/links.in: Import db-4.3.28 storage/bdb/dist/winmsi/s_winmsi.fcn: Import db-4.3.28 storage/bdb/dist/winmsi/winbuild.bat: Import db-4.3.28 storage/bdb/env/env_stat.c: Import db-4.3.28 storage/bdb/hash/hash_stub.c: Import db-4.3.28 storage/bdb/lock/lock_id.c: Import db-4.3.28 storage/bdb/lock/lock_list.c: Import db-4.3.28 storage/bdb/lock/lock_timer.c: Import db-4.3.28 storage/bdb/log/log_stat.c: Import db-4.3.28 storage/bdb/mp/mp_fmethod.c: Import db-4.3.28 storage/bdb/os/os_truncate.c: Import db-4.3.28 storage/bdb/os_win32/os_truncate.c: Import db-4.3.28 storage/bdb/os_win32/os_unlink.c: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/META.yml: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/cds.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/encrypt.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/pod.t: Import db-4.3.28 storage/bdb/perl/DB_File/META.yml: Import db-4.3.28 storage/bdb/qam/qam_stub.c: Import db-4.3.28 storage/bdb/rep/rep.src: Import db-4.3.28 storage/bdb/rep/rep_backup.c: Import db-4.3.28 storage/bdb/rep/rep_stat.c: Import db-4.3.28 storage/bdb/rep/rep_stub.c: Import db-4.3.28 storage/bdb/rpc_client/gen_client.c: Import db-4.3.28 storage/bdb/rpc_server/c/db_server_proc.c: Import db-4.3.28 storage/bdb/rpc_server/c/gen_db_server.c: Import db-4.3.28 storage/bdb/rpc_server/db_server.x: Import db-4.3.28 storage/bdb/sequence/seq_stat.c: Import db-4.3.28 storage/bdb/sequence/sequence.c: Import db-4.3.28 storage/bdb/tcl/tcl_seq.c: Import db-4.3.28 storage/bdb/dist/config.guess: Import db-4.3.28 storage/bdb/dist/config.sub: Import db-4.3.28 storage/bdb/dist/s_all: Import db-4.3.28 storage/bdb/dist/s_config: Import db-4.3.28 storage/bdb/dist/s_crypto: Import db-4.3.28 storage/bdb/dist/s_include: Import db-4.3.28 storage/bdb/dist/s_java: Import db-4.3.28 storage/bdb/dist/s_perm: Import db-4.3.28 storage/bdb/dist/s_readme: Import db-4.3.28 storage/bdb/dist/s_recover: Import db-4.3.28 storage/bdb/dist/s_rpc: Import db-4.3.28 storage/bdb/dist/s_symlink: Import db-4.3.28 storage/bdb/dist/s_tags: Import db-4.3.28 storage/bdb/dist/s_test: Import db-4.3.28 storage/bdb/dist/s_vxworks: Import db-4.3.28 storage/bdb/dist/s_win32_dsp: Import db-4.3.28 storage/bdb/dist/s_win32: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/dbinfo: Import db-4.3.28
767 lines
20 KiB
C
767 lines
20 KiB
C
/*-
|
|
* See the file LICENSE for redistribution information.
|
|
*
|
|
* Copyright (c) 1996-2004
|
|
* Sleepycat Software. All rights reserved.
|
|
*
|
|
* $Id: mp_sync.c,v 11.98 2004/10/15 16:59:43 bostic Exp $
|
|
*/
|
|
|
|
#include "db_config.h"
|
|
|
|
#ifndef NO_SYSTEM_INCLUDES
|
|
#include <sys/types.h>
|
|
|
|
#include <stdlib.h>
|
|
#endif
|
|
|
|
#include "db_int.h"
|
|
#include "dbinc/db_shash.h"
|
|
#include "dbinc/log.h"
|
|
#include "dbinc/mp.h"
|
|
|
|
typedef struct {
|
|
DB_MPOOL_HASH *track_hp; /* Hash bucket. */
|
|
|
|
roff_t track_off; /* Page file offset. */
|
|
db_pgno_t track_pgno; /* Page number. */
|
|
} BH_TRACK;
|
|
|
|
static int __bhcmp __P((const void *, const void *));
|
|
static int __memp_close_flush_files __P((DB_ENV *, DB_MPOOL *, int));
|
|
static int __memp_sync_files __P((DB_ENV *, DB_MPOOL *));
|
|
|
|
/*
|
|
* __memp_sync_pp --
|
|
* DB_ENV->memp_sync pre/post processing.
|
|
*
|
|
* PUBLIC: int __memp_sync_pp __P((DB_ENV *, DB_LSN *));
|
|
*/
|
|
int
|
|
__memp_sync_pp(dbenv, lsnp)
|
|
DB_ENV *dbenv;
|
|
DB_LSN *lsnp;
|
|
{
|
|
int rep_check, ret;
|
|
|
|
PANIC_CHECK(dbenv);
|
|
ENV_REQUIRES_CONFIG(dbenv,
|
|
dbenv->mp_handle, "memp_sync", DB_INIT_MPOOL);
|
|
|
|
/*
|
|
* If no LSN is provided, flush the entire cache (reasonable usage
|
|
* even if there's no log subsystem configured).
|
|
*/
|
|
if (lsnp != NULL)
|
|
ENV_REQUIRES_CONFIG(dbenv,
|
|
dbenv->lg_handle, "memp_sync", DB_INIT_LOG);
|
|
|
|
rep_check = IS_ENV_REPLICATED(dbenv) ? 1 : 0;
|
|
if (rep_check)
|
|
__env_rep_enter(dbenv);
|
|
ret = __memp_sync(dbenv, lsnp);
|
|
if (rep_check)
|
|
__env_db_rep_exit(dbenv);
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __memp_sync --
|
|
* DB_ENV->memp_sync.
|
|
*
|
|
* PUBLIC: int __memp_sync __P((DB_ENV *, DB_LSN *));
|
|
*/
|
|
int
|
|
__memp_sync(dbenv, lsnp)
|
|
DB_ENV *dbenv;
|
|
DB_LSN *lsnp;
|
|
{
|
|
DB_MPOOL *dbmp;
|
|
MPOOL *mp;
|
|
int ret;
|
|
|
|
dbmp = dbenv->mp_handle;
|
|
mp = dbmp->reginfo[0].primary;
|
|
|
|
/* If we've flushed to the requested LSN, return that information. */
|
|
if (lsnp != NULL) {
|
|
R_LOCK(dbenv, dbmp->reginfo);
|
|
if (log_compare(lsnp, &mp->lsn) <= 0) {
|
|
*lsnp = mp->lsn;
|
|
|
|
R_UNLOCK(dbenv, dbmp->reginfo);
|
|
return (0);
|
|
}
|
|
R_UNLOCK(dbenv, dbmp->reginfo);
|
|
}
|
|
|
|
if ((ret = __memp_sync_int(dbenv, NULL, 0, DB_SYNC_CACHE, NULL)) != 0)
|
|
return (ret);
|
|
|
|
if (lsnp != NULL) {
|
|
R_LOCK(dbenv, dbmp->reginfo);
|
|
if (log_compare(lsnp, &mp->lsn) > 0)
|
|
mp->lsn = *lsnp;
|
|
R_UNLOCK(dbenv, dbmp->reginfo);
|
|
}
|
|
|
|
return (0);
|
|
}
|
|
|
|
/*
|
|
* __memp_fsync_pp --
|
|
* DB_MPOOLFILE->sync pre/post processing.
|
|
*
|
|
* PUBLIC: int __memp_fsync_pp __P((DB_MPOOLFILE *));
|
|
*/
|
|
int
|
|
__memp_fsync_pp(dbmfp)
|
|
DB_MPOOLFILE *dbmfp;
|
|
{
|
|
DB_ENV *dbenv;
|
|
int rep_check, ret;
|
|
|
|
dbenv = dbmfp->dbenv;
|
|
|
|
PANIC_CHECK(dbenv);
|
|
MPF_ILLEGAL_BEFORE_OPEN(dbmfp, "DB_MPOOLFILE->sync");
|
|
|
|
rep_check = IS_ENV_REPLICATED(dbenv) ? 1 : 0;
|
|
if (rep_check)
|
|
__env_rep_enter(dbenv);
|
|
ret = __memp_fsync(dbmfp);
|
|
if (rep_check)
|
|
__env_db_rep_exit(dbenv);
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __memp_fsync --
|
|
* DB_MPOOLFILE->sync.
|
|
*
|
|
* PUBLIC: int __memp_fsync __P((DB_MPOOLFILE *));
|
|
*/
|
|
int
|
|
__memp_fsync(dbmfp)
|
|
DB_MPOOLFILE *dbmfp;
|
|
{
|
|
MPOOLFILE *mfp;
|
|
|
|
mfp = dbmfp->mfp;
|
|
|
|
/*
|
|
* If this handle doesn't have a file descriptor that's open for
|
|
* writing, or if the file is a temporary, or if the file hasn't
|
|
* been written since it was flushed, there's no reason to proceed
|
|
* further.
|
|
*/
|
|
if (F_ISSET(dbmfp, MP_READONLY))
|
|
return (0);
|
|
|
|
if (F_ISSET(mfp, MP_TEMP))
|
|
return (0);
|
|
|
|
if (mfp->file_written == 0)
|
|
return (0);
|
|
|
|
return (__memp_sync_int(dbmfp->dbenv, dbmfp, 0, DB_SYNC_FILE, NULL));
|
|
}
|
|
|
|
/*
|
|
* __mp_xxx_fh --
|
|
* Return a file descriptor for DB 1.85 compatibility locking.
|
|
*
|
|
* PUBLIC: int __mp_xxx_fh __P((DB_MPOOLFILE *, DB_FH **));
|
|
*/
|
|
int
|
|
__mp_xxx_fh(dbmfp, fhp)
|
|
DB_MPOOLFILE *dbmfp;
|
|
DB_FH **fhp;
|
|
{
|
|
/*
|
|
* This is a truly spectacular layering violation, intended ONLY to
|
|
* support compatibility for the DB 1.85 DB->fd call.
|
|
*
|
|
* Sync the database file to disk, creating the file as necessary.
|
|
*
|
|
* We skip the MP_READONLY and MP_TEMP tests done by memp_fsync(3).
|
|
* The MP_READONLY test isn't interesting because we will either
|
|
* already have a file descriptor (we opened the database file for
|
|
* reading) or we aren't readonly (we created the database which
|
|
* requires write privileges). The MP_TEMP test isn't interesting
|
|
* because we want to write to the backing file regardless so that
|
|
* we get a file descriptor to return.
|
|
*/
|
|
if ((*fhp = dbmfp->fhp) != NULL)
|
|
return (0);
|
|
|
|
return (__memp_sync_int(dbmfp->dbenv, dbmfp, 0, DB_SYNC_FILE, NULL));
|
|
}
|
|
|
|
/*
|
|
* __memp_sync_int --
|
|
* Mpool sync internal function.
|
|
*
|
|
* PUBLIC: int __memp_sync_int __P((DB_ENV *,
|
|
* PUBLIC: DB_MPOOLFILE *, u_int32_t, db_sync_op, u_int32_t *));
|
|
*/
|
|
int
|
|
__memp_sync_int(dbenv, dbmfp, trickle_max, op, wrotep)
|
|
DB_ENV *dbenv;
|
|
DB_MPOOLFILE *dbmfp;
|
|
u_int32_t trickle_max, *wrotep;
|
|
db_sync_op op;
|
|
{
|
|
BH *bhp;
|
|
BH_TRACK *bharray;
|
|
DB_MPOOL *dbmp;
|
|
DB_MPOOL_HASH *hp;
|
|
DB_MUTEX *mutexp;
|
|
MPOOL *c_mp, *mp;
|
|
MPOOLFILE *mfp;
|
|
roff_t last_mf_offset;
|
|
u_int32_t ar_cnt, ar_max, i, n_cache, remaining, wrote;
|
|
int filecnt, hb_lock, maxopenfd, maxwrite, maxwrite_sleep;
|
|
int pass, ret, t_ret, wait_cnt, write_cnt;
|
|
|
|
dbmp = dbenv->mp_handle;
|
|
mp = dbmp->reginfo[0].primary;
|
|
last_mf_offset = INVALID_ROFF;
|
|
filecnt = pass = wrote = 0;
|
|
|
|
/* Get shared configuration information. */
|
|
R_LOCK(dbenv, dbmp->reginfo);
|
|
maxopenfd = mp->mp_maxopenfd;
|
|
maxwrite = mp->mp_maxwrite;
|
|
maxwrite_sleep = mp->mp_maxwrite_sleep;
|
|
R_UNLOCK(dbenv, dbmp->reginfo);
|
|
|
|
/* Assume one dirty page per bucket. */
|
|
ar_max = mp->nreg * mp->htab_buckets;
|
|
if ((ret =
|
|
__os_malloc(dbenv, ar_max * sizeof(BH_TRACK), &bharray)) != 0)
|
|
return (ret);
|
|
|
|
/*
|
|
* Walk each cache's list of buffers and mark all dirty buffers to be
|
|
* written and all pinned buffers to be potentially written, depending
|
|
* on our flags.
|
|
*/
|
|
for (ar_cnt = 0, n_cache = 0; n_cache < mp->nreg; ++n_cache) {
|
|
c_mp = dbmp->reginfo[n_cache].primary;
|
|
|
|
hp = R_ADDR(&dbmp->reginfo[n_cache], c_mp->htab);
|
|
for (i = 0; i < c_mp->htab_buckets; i++, hp++) {
|
|
/*
|
|
* We can check for empty buckets before locking as we
|
|
* only care if the pointer is zero or non-zero. We
|
|
* can ignore empty buckets because we only need write
|
|
* buffers that were dirty before we started.
|
|
*/
|
|
if (SH_TAILQ_FIRST(&hp->hash_bucket, __bh) == NULL)
|
|
continue;
|
|
|
|
MUTEX_LOCK(dbenv, &hp->hash_mutex);
|
|
for (bhp = SH_TAILQ_FIRST(&hp->hash_bucket, __bh);
|
|
bhp != NULL; bhp = SH_TAILQ_NEXT(bhp, hq, __bh)) {
|
|
/* Always ignore unreferenced, clean pages. */
|
|
if (bhp->ref == 0 && !F_ISSET(bhp, BH_DIRTY))
|
|
continue;
|
|
|
|
/*
|
|
* Checkpoints have to wait on all pinned pages,
|
|
* as pages may be marked dirty when returned to
|
|
* the cache.
|
|
*
|
|
* File syncs only wait on pages both pinned and
|
|
* dirty. (We don't care if pages are marked
|
|
* dirty when returned to the cache, that means
|
|
* there's another writing thread and flushing
|
|
* the cache for this handle is meaningless.)
|
|
*/
|
|
if (op == DB_SYNC_FILE &&
|
|
!F_ISSET(bhp, BH_DIRTY))
|
|
continue;
|
|
|
|
mfp = R_ADDR(dbmp->reginfo, bhp->mf_offset);
|
|
|
|
/*
|
|
* Ignore temporary files -- this means you
|
|
* can't even flush temporary files by handle.
|
|
* (Checkpoint doesn't require temporary files
|
|
* be flushed and the underlying buffer write
|
|
* write routine may not be able to write it
|
|
* anyway.)
|
|
*/
|
|
if (F_ISSET(mfp, MP_TEMP))
|
|
continue;
|
|
|
|
/*
|
|
* If we're flushing a specific file, see if
|
|
* this page is from that file.
|
|
*/
|
|
if (dbmfp != NULL && mfp != dbmfp->mfp)
|
|
continue;
|
|
|
|
/*
|
|
* Ignore files that aren't involved in DB's
|
|
* transactional operations during checkpoints.
|
|
*/
|
|
if (dbmfp == NULL && mfp->lsn_off == -1)
|
|
continue;
|
|
|
|
/* Track the buffer, we want it. */
|
|
bharray[ar_cnt].track_hp = hp;
|
|
bharray[ar_cnt].track_pgno = bhp->pgno;
|
|
bharray[ar_cnt].track_off = bhp->mf_offset;
|
|
ar_cnt++;
|
|
|
|
/*
|
|
* If we run out of space, double and continue.
|
|
* Don't stop at trickle_max, we want to sort
|
|
* as large a sample set as possible in order
|
|
* to minimize disk seeks.
|
|
*/
|
|
if (ar_cnt >= ar_max) {
|
|
if ((ret = __os_realloc(dbenv,
|
|
(ar_max * 2) * sizeof(BH_TRACK),
|
|
&bharray)) != 0)
|
|
break;
|
|
ar_max *= 2;
|
|
}
|
|
}
|
|
MUTEX_UNLOCK(dbenv, &hp->hash_mutex);
|
|
|
|
if (ret != 0)
|
|
goto err;
|
|
}
|
|
}
|
|
|
|
/* If there no buffers to write, we're done. */
|
|
if (ar_cnt == 0)
|
|
goto done;
|
|
|
|
/*
|
|
* Write the buffers in file/page order, trying to reduce seeks by the
|
|
* filesystem and, when pages are smaller than filesystem block sizes,
|
|
* reduce the actual number of writes.
|
|
*/
|
|
if (ar_cnt > 1)
|
|
qsort(bharray, ar_cnt, sizeof(BH_TRACK), __bhcmp);
|
|
|
|
/*
|
|
* If we're trickling buffers, only write enough to reach the correct
|
|
* percentage.
|
|
*/
|
|
if (op == DB_SYNC_TRICKLE && ar_cnt > trickle_max)
|
|
ar_cnt = trickle_max;
|
|
|
|
/*
|
|
* Flush the log. We have to ensure the log records reflecting the
|
|
* changes on the database pages we're writing have already made it
|
|
* to disk. We still have to check the log each time we write a page
|
|
* (because pages we are about to write may be modified after we have
|
|
* flushed the log), but in general this will at least avoid any I/O
|
|
* on the log's part.
|
|
*/
|
|
if (LOGGING_ON(dbenv) && (ret = __log_flush(dbenv, NULL)) != 0)
|
|
goto err;
|
|
|
|
/*
|
|
* Walk the array, writing buffers. When we write a buffer, we NULL
|
|
* out its hash bucket pointer so we don't process a slot more than
|
|
* once.
|
|
*/
|
|
for (i = pass = write_cnt = 0, remaining = ar_cnt; remaining > 0; ++i) {
|
|
if (i >= ar_cnt) {
|
|
i = 0;
|
|
++pass;
|
|
__os_sleep(dbenv, 1, 0);
|
|
}
|
|
if ((hp = bharray[i].track_hp) == NULL)
|
|
continue;
|
|
|
|
/* Lock the hash bucket and find the buffer. */
|
|
mutexp = &hp->hash_mutex;
|
|
MUTEX_LOCK(dbenv, mutexp);
|
|
for (bhp = SH_TAILQ_FIRST(&hp->hash_bucket, __bh);
|
|
bhp != NULL; bhp = SH_TAILQ_NEXT(bhp, hq, __bh))
|
|
if (bhp->pgno == bharray[i].track_pgno &&
|
|
bhp->mf_offset == bharray[i].track_off)
|
|
break;
|
|
|
|
/*
|
|
* If we can't find the buffer we're done, somebody else had
|
|
* to have written it.
|
|
*
|
|
* If the buffer isn't pinned or dirty, we're done, there's
|
|
* no work needed.
|
|
*/
|
|
if (bhp == NULL || (bhp->ref == 0 && !F_ISSET(bhp, BH_DIRTY))) {
|
|
MUTEX_UNLOCK(dbenv, mutexp);
|
|
--remaining;
|
|
bharray[i].track_hp = NULL;
|
|
continue;
|
|
}
|
|
|
|
/*
|
|
* If the buffer is locked by another thread, ignore it, we'll
|
|
* come back to it.
|
|
*
|
|
* If the buffer is pinned and it's only the first or second
|
|
* time we have looked at it, ignore it, we'll come back to
|
|
* it.
|
|
*
|
|
* In either case, skip the buffer if we're not required to
|
|
* write it.
|
|
*/
|
|
if (F_ISSET(bhp, BH_LOCKED) || (bhp->ref != 0 && pass < 2)) {
|
|
MUTEX_UNLOCK(dbenv, mutexp);
|
|
if (op != DB_SYNC_CACHE && op != DB_SYNC_FILE) {
|
|
--remaining;
|
|
bharray[i].track_hp = NULL;
|
|
}
|
|
continue;
|
|
}
|
|
|
|
/*
|
|
* The buffer is either pinned or dirty.
|
|
*
|
|
* Set the sync wait-for count, used to count down outstanding
|
|
* references to this buffer as they are returned to the cache.
|
|
*/
|
|
bhp->ref_sync = bhp->ref;
|
|
|
|
/* Pin the buffer into memory and lock it. */
|
|
++bhp->ref;
|
|
F_SET(bhp, BH_LOCKED);
|
|
MUTEX_LOCK(dbenv, &bhp->mutex);
|
|
|
|
/*
|
|
* Unlock the hash bucket and wait for the wait-for count to
|
|
* go to 0. No new thread can acquire the buffer because we
|
|
* have it locked.
|
|
*
|
|
* If a thread attempts to re-pin a page, the wait-for count
|
|
* will never go to 0 (the thread spins on our buffer lock,
|
|
* while we spin on the thread's ref count). Give up if we
|
|
* don't get the buffer in 3 seconds, we can try again later.
|
|
*
|
|
* If, when the wait-for count goes to 0, the buffer is found
|
|
* to be dirty, write it.
|
|
*/
|
|
MUTEX_UNLOCK(dbenv, mutexp);
|
|
for (wait_cnt = 1;
|
|
bhp->ref_sync != 0 && wait_cnt < 4; ++wait_cnt)
|
|
__os_sleep(dbenv, 1, 0);
|
|
MUTEX_LOCK(dbenv, mutexp);
|
|
hb_lock = 1;
|
|
|
|
/*
|
|
* If we've switched files, check to see if we're configured
|
|
* to close file descriptors.
|
|
*/
|
|
if (maxopenfd != 0 && bhp->mf_offset != last_mf_offset) {
|
|
if (++filecnt >= maxopenfd) {
|
|
filecnt = 0;
|
|
if ((ret = __memp_close_flush_files(
|
|
dbenv, dbmp, 1)) != 0)
|
|
break;
|
|
}
|
|
last_mf_offset = bhp->mf_offset;
|
|
}
|
|
|
|
/*
|
|
* If the ref_sync count has gone to 0, we're going to be done
|
|
* with this buffer no matter what happens.
|
|
*/
|
|
if (bhp->ref_sync == 0) {
|
|
--remaining;
|
|
bharray[i].track_hp = NULL;
|
|
}
|
|
|
|
/*
|
|
* If the ref_sync count has gone to 0 and the buffer is still
|
|
* dirty, we write it. We only try to write the buffer once.
|
|
*/
|
|
if (bhp->ref_sync == 0 && F_ISSET(bhp, BH_DIRTY)) {
|
|
hb_lock = 0;
|
|
MUTEX_UNLOCK(dbenv, mutexp);
|
|
|
|
mfp = R_ADDR(dbmp->reginfo, bhp->mf_offset);
|
|
if ((ret = __memp_bhwrite(dbmp, hp, mfp, bhp, 1)) == 0)
|
|
++wrote;
|
|
else
|
|
__db_err(dbenv, "%s: unable to flush page: %lu",
|
|
__memp_fns(dbmp, mfp), (u_long)bhp->pgno);
|
|
|
|
/*
|
|
* Avoid saturating the disk, sleep once we've done
|
|
* some number of writes.
|
|
*/
|
|
if (maxwrite != 0 && ++write_cnt >= maxwrite) {
|
|
write_cnt = 0;
|
|
__os_sleep(dbenv, 0, (u_long)maxwrite_sleep);
|
|
}
|
|
}
|
|
|
|
/*
|
|
* If ref_sync count never went to 0, the buffer was written
|
|
* by another thread, or the write failed, we still have the
|
|
* buffer locked.
|
|
*
|
|
* We may or may not currently hold the hash bucket mutex. If
|
|
* the __memp_bhwrite -> __memp_pgwrite call was successful,
|
|
* then __memp_pgwrite will have swapped the buffer lock for
|
|
* the hash lock. All other call paths will leave us without
|
|
* the hash bucket lock.
|
|
*
|
|
* The order of mutexes above was to acquire the buffer lock
|
|
* while holding the hash bucket lock. Don't deadlock here,
|
|
* release the buffer lock and then acquire the hash bucket
|
|
* lock.
|
|
*/
|
|
if (F_ISSET(bhp, BH_LOCKED)) {
|
|
F_CLR(bhp, BH_LOCKED);
|
|
MUTEX_UNLOCK(dbenv, &bhp->mutex);
|
|
|
|
if (!hb_lock)
|
|
MUTEX_LOCK(dbenv, mutexp);
|
|
}
|
|
|
|
/*
|
|
* Reset the ref_sync count regardless of our success, we're
|
|
* done with this buffer for now.
|
|
*/
|
|
bhp->ref_sync = 0;
|
|
|
|
/* Discard our reference and unlock the bucket. */
|
|
--bhp->ref;
|
|
MUTEX_UNLOCK(dbenv, mutexp);
|
|
|
|
if (ret != 0)
|
|
break;
|
|
}
|
|
|
|
done: /*
|
|
* If doing a checkpoint or flushing a file for the application, we
|
|
* have to force the pages to disk. We don't do this as we go along
|
|
* because we want to give the OS as much time as possible to lazily
|
|
* flush, and because we have to flush files that might not even have
|
|
* had dirty buffers in the cache, so we have to walk the files list.
|
|
*/
|
|
if (ret == 0 && (op == DB_SYNC_CACHE || op == DB_SYNC_FILE)) {
|
|
if (dbmfp == NULL)
|
|
ret = __memp_sync_files(dbenv, dbmp);
|
|
else
|
|
ret = __os_fsync(dbenv, dbmfp->fhp);
|
|
}
|
|
|
|
/* If we've opened files to flush pages, close them. */
|
|
if ((t_ret = __memp_close_flush_files(dbenv, dbmp, 0)) != 0 && ret == 0)
|
|
ret = t_ret;
|
|
|
|
err: __os_free(dbenv, bharray);
|
|
if (wrotep != NULL)
|
|
*wrotep = wrote;
|
|
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __memp_sync_files --
|
|
* Sync all the files in the environment, open or not.
|
|
*/
|
|
static
|
|
int __memp_sync_files(dbenv, dbmp)
|
|
DB_ENV *dbenv;
|
|
DB_MPOOL *dbmp;
|
|
{
|
|
DB_MPOOLFILE *dbmfp;
|
|
MPOOL *mp;
|
|
MPOOLFILE *mfp;
|
|
int final_ret, ret;
|
|
|
|
final_ret = 0;
|
|
mp = dbmp->reginfo[0].primary;
|
|
|
|
R_LOCK(dbenv, dbmp->reginfo);
|
|
for (mfp = SH_TAILQ_FIRST(&mp->mpfq, __mpoolfile);
|
|
mfp != NULL; mfp = SH_TAILQ_NEXT(mfp, q, __mpoolfile)) {
|
|
if (!mfp->file_written ||
|
|
mfp->deadfile || F_ISSET(mfp, MP_TEMP))
|
|
continue;
|
|
|
|
/*
|
|
* Look for an already open, writeable handle (fsync doesn't
|
|
* work on read-only Windows handles).
|
|
*/
|
|
ret = 0;
|
|
MUTEX_THREAD_LOCK(dbenv, dbmp->mutexp);
|
|
for (dbmfp = TAILQ_FIRST(&dbmp->dbmfq);
|
|
dbmfp != NULL; dbmfp = TAILQ_NEXT(dbmfp, q)) {
|
|
if (dbmfp->mfp != mfp || F_ISSET(dbmfp, MP_READONLY))
|
|
continue;
|
|
ret = __os_fsync(dbenv, dbmfp->fhp);
|
|
break;
|
|
}
|
|
MUTEX_THREAD_UNLOCK(dbenv, dbmp->mutexp);
|
|
|
|
/* If we don't find one, open one. */
|
|
if (dbmfp == NULL)
|
|
ret = __memp_mf_sync(dbmp, mfp);
|
|
if (ret != 0) {
|
|
__db_err(dbenv, "%s: unable to flush: %s",
|
|
(char *)R_ADDR(dbmp->reginfo, mfp->path_off),
|
|
db_strerror(ret));
|
|
if (final_ret == 0)
|
|
final_ret = ret;
|
|
continue;
|
|
}
|
|
|
|
/*
|
|
* If we wrote the file and there are no open handles (or there
|
|
* is a single open handle, and it's the one we opened to write
|
|
* buffers during checkpoint), clear the file_written flag. We
|
|
* do this so that applications opening thousands of files don't
|
|
* loop here opening and flushing those files during checkpoint.
|
|
*
|
|
* The danger here is if a buffer were to be written as part of
|
|
* a checkpoint, and then not be flushed to disk. This cannot
|
|
* happen because we only clear file_written when there are no
|
|
* other users of the MPOOLFILE in the system, and, as we hold
|
|
* the region lock, no possibility of another thread of control
|
|
* racing with us to open a MPOOLFILE.
|
|
*/
|
|
if (mfp->mpf_cnt == 0 || (mfp->mpf_cnt == 1 &&
|
|
dbmfp != NULL && F_ISSET(dbmfp, MP_FLUSH)))
|
|
mfp->file_written = 0;
|
|
}
|
|
R_UNLOCK(dbenv, dbmp->reginfo);
|
|
|
|
return (final_ret);
|
|
}
|
|
|
|
/*
|
|
* __memp_mf_sync --
|
|
* Flush an MPOOLFILE.
|
|
*
|
|
* Should only be used when the file is not already open in this process.
|
|
*
|
|
* PUBLIC: int __memp_mf_sync __P((DB_MPOOL *, MPOOLFILE *));
|
|
*/
|
|
int
|
|
__memp_mf_sync(dbmp, mfp)
|
|
DB_MPOOL *dbmp;
|
|
MPOOLFILE *mfp;
|
|
{
|
|
DB_ENV *dbenv;
|
|
DB_FH *fhp;
|
|
int ret, t_ret;
|
|
char *rpath;
|
|
|
|
dbenv = dbmp->dbenv;
|
|
|
|
/*
|
|
* Expects caller to be holding the region lock: we're using the path
|
|
* name and __memp_nameop might try and rename the file.
|
|
*/
|
|
if ((ret = __db_appname(dbenv, DB_APP_DATA,
|
|
R_ADDR(dbmp->reginfo, mfp->path_off), 0, NULL,
|
|
&rpath)) == 0) {
|
|
if ((ret = __os_open(dbenv, rpath, 0, 0, &fhp)) == 0) {
|
|
ret = __os_fsync(dbenv, fhp);
|
|
if ((t_ret =
|
|
__os_closehandle(dbenv, fhp)) != 0 && ret == 0)
|
|
ret = t_ret;
|
|
}
|
|
__os_free(dbenv, rpath);
|
|
}
|
|
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __memp_close_flush_files --
|
|
* Close files opened only to flush buffers.
|
|
*/
|
|
static int
|
|
__memp_close_flush_files(dbenv, dbmp, dosync)
|
|
DB_ENV *dbenv;
|
|
DB_MPOOL *dbmp;
|
|
int dosync;
|
|
{
|
|
DB_MPOOLFILE *dbmfp;
|
|
MPOOLFILE *mfp;
|
|
int ret;
|
|
|
|
/*
|
|
* The routine exists because we must close files opened by sync to
|
|
* flush buffers. There are two cases: first, extent files have to
|
|
* be closed so they may be removed when empty. Second, regular
|
|
* files have to be closed so we don't run out of descriptors (for
|
|
* example, an application partitioning its data into databases
|
|
* based on timestamps, so there's a continually increasing set of
|
|
* files).
|
|
*
|
|
* We mark files opened in the __memp_bhwrite() function with the
|
|
* MP_FLUSH flag. Here we walk through our file descriptor list,
|
|
* and, if a file was opened by __memp_bhwrite(), we close it.
|
|
*/
|
|
retry: MUTEX_THREAD_LOCK(dbenv, dbmp->mutexp);
|
|
for (dbmfp = TAILQ_FIRST(&dbmp->dbmfq);
|
|
dbmfp != NULL; dbmfp = TAILQ_NEXT(dbmfp, q))
|
|
if (F_ISSET(dbmfp, MP_FLUSH)) {
|
|
F_CLR(dbmfp, MP_FLUSH);
|
|
MUTEX_THREAD_UNLOCK(dbenv, dbmp->mutexp);
|
|
if (dosync) {
|
|
if ((ret = __os_fsync(dbenv, dbmfp->fhp)) != 0)
|
|
return (ret);
|
|
/*
|
|
* If the file is clean and we have the only
|
|
* open handle on the file, clear the dirty
|
|
* flag so we don't re-open and sync it again.
|
|
*/
|
|
mfp = dbmfp->mfp;
|
|
if (mfp->mpf_cnt == 1) {
|
|
R_LOCK(dbenv, dbmp->reginfo);
|
|
if (mfp->mpf_cnt == 1)
|
|
mfp->file_written = 0;
|
|
R_UNLOCK(dbenv, dbmp->reginfo);
|
|
}
|
|
}
|
|
if ((ret = __memp_fclose(dbmfp, 0)) != 0)
|
|
return (ret);
|
|
goto retry;
|
|
}
|
|
MUTEX_THREAD_UNLOCK(dbenv, dbmp->mutexp);
|
|
|
|
return (0);
|
|
}
|
|
|
|
static int
|
|
__bhcmp(p1, p2)
|
|
const void *p1, *p2;
|
|
{
|
|
BH_TRACK *bhp1, *bhp2;
|
|
|
|
bhp1 = (BH_TRACK *)p1;
|
|
bhp2 = (BH_TRACK *)p2;
|
|
|
|
/* Sort by file (shared memory pool offset). */
|
|
if (bhp1->track_off < bhp2->track_off)
|
|
return (-1);
|
|
if (bhp1->track_off > bhp2->track_off)
|
|
return (1);
|
|
|
|
/*
|
|
* !!!
|
|
* Defend against badly written quicksort code calling the comparison
|
|
* function with two identical pointers (e.g., WATCOM C++ (Power++)).
|
|
*/
|
|
if (bhp1->track_pgno < bhp2->track_pgno)
|
|
return (-1);
|
|
if (bhp1->track_pgno > bhp2->track_pgno)
|
|
return (1);
|
|
return (0);
|
|
}
|