📄 hash.src
字号:
/*- * See the file LICENSE for redistribution information. * * Copyright (c) 1996-2002 * Sleepycat Software. All rights reserved. * * $Id: hash.src,v 10.38 2002/04/17 19:03:10 krinsky Exp $ *//* * Copyright (c) 1995, 1996 * Margo Seltzer. All rights reserved. *//* * Copyright (c) 1995, 1996 * The President and Fellows of Harvard University. All rights reserved. * * This code is derived from software contributed to Berkeley by * Margo Seltzer. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of the University nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */PREFIX __hamDBPRIVATEINCLUDE #include "db_config.h"INCLUDEINCLUDE #ifndef NO_SYSTEM_INCLUDESINCLUDE #include <sys/types.h>INCLUDEINCLUDE #include <ctype.h>INCLUDE #include <string.h>INCLUDE #endifINCLUDEINCLUDE #include "db_int.h"INCLUDE #include "dbinc/crypto.h"INCLUDE #include "dbinc/db_page.h"INCLUDE #include "dbinc/db_dispatch.h"INCLUDE #include "dbinc/db_am.h"INCLUDE #include "dbinc/hash.h"INCLUDE #include "dbinc/rep.h"INCLUDE #include "dbinc/log.h"INCLUDE #include "dbinc/txn.h"INCLUDE/* * HASH-insdel: used for hash to insert/delete a pair of entries onto a master * page. The pair might be regular key/data pairs or they might be the * structures that refer to off page items, duplicates or offpage duplicates. * opcode - PUTPAIR/DELPAIR + big masks * fileid - identifies the file referenced * pgno - page within file * ndx - index on the page of the item being added (item index) * pagelsn - lsn on the page before the update * key - the key being inserted * data - the data being inserted */BEGIN insdel 21ARG opcode u_int32_t luDB fileid int32_t ldWRLOCK pgno db_pgno_t luARG ndx u_int32_t luPOINTER pagelsn DB_LSN * luDBT key DBT sDBT data DBT sEND/* * Used to add and remove overflow pages. * prev_pgno is the previous page that is going to get modified to * point to this one. If this is the first page in a chain * then prev_pgno should be PGNO_INVALID. * new_pgno is the page being allocated. * next_pgno is the page that follows this one. On allocation, * this should be PGNO_INVALID. For deletes, it may exist. * pagelsn is the old lsn on the page. */BEGIN newpage 22ARG opcode u_int32_t luDB fileid int32_t ldWRLOCKNZ prev_pgno db_pgno_t luPOINTER prevlsn DB_LSN * luWRLOCKNZ new_pgno db_pgno_t luPOINTER pagelsn DB_LSN * luWRLOCKNZ next_pgno db_pgno_t luPOINTER nextlsn DB_LSN * luEND/* * Splitting requires two types of log messages. The second logs the * data on the original page. To redo the split, we have to visit the * new page (pages) and add the items back on the page if they are not * yet there. */BEGIN splitdata 24DB fileid int32_t ldARG opcode u_int32_t luWRLOCK pgno db_pgno_t luPGDBT pageimage DBT sPOINTER pagelsn DB_LSN * luEND/* * HASH-replace: is used for hash to handle partial puts that only * affect a single master page. * fileid - identifies the file referenced * pgno - page within file * ndx - index on the page of the item being modified (item index) * pagelsn - lsn on the page before the update * off - offset in the old item where the new item is going. * olditem - DBT that describes the part of the item being replaced. * newitem - DBT of the new item. * makedup - this was a replacement that made an item a duplicate. */BEGIN replace 25DB fileid int32_t ldWRLOCK pgno db_pgno_t luARG ndx u_int32_t luPOINTER pagelsn DB_LSN * luARG off int32_t ldDBT olditem DBT sDBT newitem DBT sARG makedup u_int32_t luEND/* * Used when we empty the first page in a bucket and there are pages after * it. The page after it gets copied into the bucket page (since bucket * pages have to be in fixed locations). * pgno: the bucket page * pagelsn: the old LSN on the bucket page * next_pgno: the page number of the next page * nnext_pgno: page after next_pgno (may need to change its prev) * nnextlsn: the LSN of nnext_pgno. */BEGIN copypage 28DB fileid int32_t ldWRLOCK pgno db_pgno_t luPOINTER pagelsn DB_LSN * luWRLOCK next_pgno db_pgno_t luPOINTER nextlsn DB_LSN * luWRLOCKNZ nnext_pgno db_pgno_t luPOINTER nnextlsn DB_LSN * luPGDBT page DBT sEND/* * This record logs the meta-data aspects of a split operation. It has enough * information so that we can record both an individual page allocation as well * as a group allocation which we do because in sub databases, the pages in * a hash doubling, must be contiguous. If we do a group allocation, the * number of pages allocated is bucket + 1, pgno is the page number of the * first newly allocated bucket. * * bucket: Old maximum bucket number. * mmpgno: Master meta-data page number (0 if same as mpgno). * mmetalsn: Lsn of the master meta-data page. * mpgno: Meta-data page number. * metalsn: Lsn of the meta-data page. * pgno: Page allocated to bucket + 1 (first newly allocated page) * pagelsn: Lsn of either the first page allocated (if newalloc == 0) or * the last page allocated (if newalloc == 1). * newalloc: 1 indicates that this record did the actual allocation; * 0 indicates that the pages were already allocated from a * previous (failed) allocation. */BEGIN metagroup 29DB fileid int32_t ldARG bucket u_int32_t luWRLOCK mmpgno db_pgno_t luPOINTER mmetalsn DB_LSN * luWRLOCKNZ mpgno db_pgno_t luPOINTER metalsn DB_LSN * luWRLOCK pgno db_pgno_t luPOINTER pagelsn DB_LSN * luARG newalloc u_int32_t luEND/* * groupalloc * * This is used in conjunction with MPOOL_NEW_GROUP when we are creating * a new database to make sure that we recreate or reclaim free pages * when we allocate a chunk of contiguous ones during database creation. * * pgno: meta-data page number * metalsn: meta-data lsn * start_pgno: starting page number * num: number of allocated pages */BEGIN groupalloc 32DB fileid int32_t ldPOINTER meta_lsn DB_LSN * luWRLOCK start_pgno db_pgno_t luARG num u_int32_t luARG free db_pgno_t luEND/* * Records for backing out cursor adjustment. * curadj - added or deleted a record or a dup * within a record. * pgno - page that was effected * indx - indx of recrod effected. * len - if a dup its length. * dup_off - if a dup its offset * add - 1 if add 0 if delete * is_dup - 1 if dup 0 otherwise. * order - order assigned to this deleted record or dup. * * chgpg - rmoved a page, move the records to a new page * mode - CHGPG page was deleted or records move to new page. * - SPLIT we split a bucket * - DUP we convered to off page duplicates. * old_pgno, new_pgno - old and new page numbers. * old_index, new_index - old and new index numbers, NDX_INVALID if * it effects all records on the page. * For three opcodes new in 3.3 (DB_HAM_DELFIRSTPG, DELMIDPG, * and DELLASTPG), we overload old_indx and new_indx to avoid * needing a new log record type: old_indx stores the only * indx of interest to these records, and new_indx stores the * order that's assigned to the lowest deleted record we're * moving. */BEGIN curadj 33DB fileid int32_t ldARG pgno db_pgno_t luARG indx u_int32_t luARG len u_int32_t luARG dup_off u_int32_t luARG add int ldARG is_dup int ldARG order u_int32_t luENDBEGIN chgpg 34DB fileid int32_t ldARG mode db_ham_mode ldARG old_pgno db_pgno_t luARG new_pgno db_pgno_t luARG old_indx u_int32_t luARG new_indx u_int32_t luEND
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -