158f0484fSRodney W. Grimes /*-
2*8a16b7a1SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause
3*8a16b7a1SPedro F. Giffuni *
4f1e396bcSPaul Traina * Copyright (c) 1990, 1993, 1994
558f0484fSRodney W. Grimes * The Regents of the University of California. All rights reserved.
658f0484fSRodney W. Grimes *
758f0484fSRodney W. Grimes * This code is derived from software contributed to Berkeley by
858f0484fSRodney W. Grimes * Mike Olson.
958f0484fSRodney W. Grimes *
1058f0484fSRodney W. Grimes * Redistribution and use in source and binary forms, with or without
1158f0484fSRodney W. Grimes * modification, are permitted provided that the following conditions
1258f0484fSRodney W. Grimes * are met:
1358f0484fSRodney W. Grimes * 1. Redistributions of source code must retain the above copyright
1458f0484fSRodney W. Grimes * notice, this list of conditions and the following disclaimer.
1558f0484fSRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright
1658f0484fSRodney W. Grimes * notice, this list of conditions and the following disclaimer in the
1758f0484fSRodney W. Grimes * documentation and/or other materials provided with the distribution.
18fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors
1958f0484fSRodney W. Grimes * may be used to endorse or promote products derived from this software
2058f0484fSRodney W. Grimes * without specific prior written permission.
2158f0484fSRodney W. Grimes *
2258f0484fSRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
2358f0484fSRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2458f0484fSRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2558f0484fSRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
2658f0484fSRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2758f0484fSRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2858f0484fSRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2958f0484fSRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
3058f0484fSRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
3158f0484fSRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
3258f0484fSRodney W. Grimes * SUCH DAMAGE.
3358f0484fSRodney W. Grimes */
3458f0484fSRodney W. Grimes
35d201fe46SDaniel Eischen #include "namespace.h"
3658f0484fSRodney W. Grimes #include <sys/param.h>
3758f0484fSRodney W. Grimes
3858f0484fSRodney W. Grimes #include <errno.h>
3958f0484fSRodney W. Grimes #include <stdio.h>
4058f0484fSRodney W. Grimes #include <stdlib.h>
4158f0484fSRodney W. Grimes #include <string.h>
4258f0484fSRodney W. Grimes #include <unistd.h>
43d201fe46SDaniel Eischen #include "un-namespace.h"
4458f0484fSRodney W. Grimes
4558f0484fSRodney W. Grimes #include <db.h>
4658f0484fSRodney W. Grimes #include "btree.h"
4758f0484fSRodney W. Grimes
48c05ac53bSDavid E. O'Brien static int bt_meta(BTREE *);
4958f0484fSRodney W. Grimes
5058f0484fSRodney W. Grimes /*
5158f0484fSRodney W. Grimes * BT_CLOSE -- Close a btree.
5258f0484fSRodney W. Grimes *
5358f0484fSRodney W. Grimes * Parameters:
5458f0484fSRodney W. Grimes * dbp: pointer to access method
5558f0484fSRodney W. Grimes *
5658f0484fSRodney W. Grimes * Returns:
5758f0484fSRodney W. Grimes * RET_ERROR, RET_SUCCESS
5858f0484fSRodney W. Grimes */
5958f0484fSRodney W. Grimes int
__bt_close(DB * dbp)600ac22237SXin LI __bt_close(DB *dbp)
6158f0484fSRodney W. Grimes {
6258f0484fSRodney W. Grimes BTREE *t;
6358f0484fSRodney W. Grimes int fd;
6458f0484fSRodney W. Grimes
6558f0484fSRodney W. Grimes t = dbp->internal;
6658f0484fSRodney W. Grimes
6758f0484fSRodney W. Grimes /* Toss any page pinned across calls. */
6858f0484fSRodney W. Grimes if (t->bt_pinned != NULL) {
6958f0484fSRodney W. Grimes mpool_put(t->bt_mp, t->bt_pinned, 0);
7058f0484fSRodney W. Grimes t->bt_pinned = NULL;
7158f0484fSRodney W. Grimes }
7258f0484fSRodney W. Grimes
73f1e396bcSPaul Traina /* Sync the tree. */
7458f0484fSRodney W. Grimes if (__bt_sync(dbp, 0) == RET_ERROR)
7558f0484fSRodney W. Grimes return (RET_ERROR);
7658f0484fSRodney W. Grimes
77f1e396bcSPaul Traina /* Close the memory pool. */
7858f0484fSRodney W. Grimes if (mpool_close(t->bt_mp) == RET_ERROR)
7958f0484fSRodney W. Grimes return (RET_ERROR);
8058f0484fSRodney W. Grimes
81f1e396bcSPaul Traina /* Free random memory. */
82f1e396bcSPaul Traina if (t->bt_cursor.key.data != NULL) {
83f1e396bcSPaul Traina free(t->bt_cursor.key.data);
84f1e396bcSPaul Traina t->bt_cursor.key.size = 0;
85f1e396bcSPaul Traina t->bt_cursor.key.data = NULL;
86f1e396bcSPaul Traina }
87f1e396bcSPaul Traina if (t->bt_rkey.data) {
88f1e396bcSPaul Traina free(t->bt_rkey.data);
89f1e396bcSPaul Traina t->bt_rkey.size = 0;
90f1e396bcSPaul Traina t->bt_rkey.data = NULL;
91f1e396bcSPaul Traina }
92f1e396bcSPaul Traina if (t->bt_rdata.data) {
93f1e396bcSPaul Traina free(t->bt_rdata.data);
94f1e396bcSPaul Traina t->bt_rdata.size = 0;
95f1e396bcSPaul Traina t->bt_rdata.data = NULL;
96f1e396bcSPaul Traina }
9758f0484fSRodney W. Grimes
9858f0484fSRodney W. Grimes fd = t->bt_fd;
9958f0484fSRodney W. Grimes free(t);
10058f0484fSRodney W. Grimes free(dbp);
1019233c4d9SJason Evans return (_close(fd) ? RET_ERROR : RET_SUCCESS);
10258f0484fSRodney W. Grimes }
10358f0484fSRodney W. Grimes
10458f0484fSRodney W. Grimes /*
10558f0484fSRodney W. Grimes * BT_SYNC -- sync the btree to disk.
10658f0484fSRodney W. Grimes *
10758f0484fSRodney W. Grimes * Parameters:
10858f0484fSRodney W. Grimes * dbp: pointer to access method
10958f0484fSRodney W. Grimes *
11058f0484fSRodney W. Grimes * Returns:
11158f0484fSRodney W. Grimes * RET_SUCCESS, RET_ERROR.
11258f0484fSRodney W. Grimes */
11358f0484fSRodney W. Grimes int
__bt_sync(const DB * dbp,u_int flags)1140ac22237SXin LI __bt_sync(const DB *dbp, u_int flags)
11558f0484fSRodney W. Grimes {
11658f0484fSRodney W. Grimes BTREE *t;
11758f0484fSRodney W. Grimes int status;
11858f0484fSRodney W. Grimes
11958f0484fSRodney W. Grimes t = dbp->internal;
12058f0484fSRodney W. Grimes
12158f0484fSRodney W. Grimes /* Toss any page pinned across calls. */
12258f0484fSRodney W. Grimes if (t->bt_pinned != NULL) {
12358f0484fSRodney W. Grimes mpool_put(t->bt_mp, t->bt_pinned, 0);
12458f0484fSRodney W. Grimes t->bt_pinned = NULL;
12558f0484fSRodney W. Grimes }
12658f0484fSRodney W. Grimes
12758f0484fSRodney W. Grimes /* Sync doesn't currently take any flags. */
12858f0484fSRodney W. Grimes if (flags != 0) {
12958f0484fSRodney W. Grimes errno = EINVAL;
13058f0484fSRodney W. Grimes return (RET_ERROR);
13158f0484fSRodney W. Grimes }
13258f0484fSRodney W. Grimes
133d191be26SPedro F. Giffuni if (F_ISSET(t, B_INMEM | B_RDONLY) ||
134d191be26SPedro F. Giffuni !F_ISSET(t, B_MODIFIED | B_METADIRTY))
13558f0484fSRodney W. Grimes return (RET_SUCCESS);
13658f0484fSRodney W. Grimes
137f1e396bcSPaul Traina if (F_ISSET(t, B_METADIRTY) && bt_meta(t) == RET_ERROR)
13858f0484fSRodney W. Grimes return (RET_ERROR);
13958f0484fSRodney W. Grimes
14058f0484fSRodney W. Grimes if ((status = mpool_sync(t->bt_mp)) == RET_SUCCESS)
141f1e396bcSPaul Traina F_CLR(t, B_MODIFIED);
14258f0484fSRodney W. Grimes
14358f0484fSRodney W. Grimes return (status);
14458f0484fSRodney W. Grimes }
14558f0484fSRodney W. Grimes
14658f0484fSRodney W. Grimes /*
14758f0484fSRodney W. Grimes * BT_META -- write the tree meta data to disk.
14858f0484fSRodney W. Grimes *
14958f0484fSRodney W. Grimes * Parameters:
15058f0484fSRodney W. Grimes * t: tree
15158f0484fSRodney W. Grimes *
15258f0484fSRodney W. Grimes * Returns:
15358f0484fSRodney W. Grimes * RET_ERROR, RET_SUCCESS
15458f0484fSRodney W. Grimes */
15558f0484fSRodney W. Grimes static int
bt_meta(BTREE * t)1560ac22237SXin LI bt_meta(BTREE *t)
15758f0484fSRodney W. Grimes {
15858f0484fSRodney W. Grimes BTMETA m;
15958f0484fSRodney W. Grimes void *p;
16058f0484fSRodney W. Grimes
16158f0484fSRodney W. Grimes if ((p = mpool_get(t->bt_mp, P_META, 0)) == NULL)
16258f0484fSRodney W. Grimes return (RET_ERROR);
16358f0484fSRodney W. Grimes
16458f0484fSRodney W. Grimes /* Fill in metadata. */
165f1e396bcSPaul Traina m.magic = BTREEMAGIC;
166f1e396bcSPaul Traina m.version = BTREEVERSION;
167f1e396bcSPaul Traina m.psize = t->bt_psize;
168f1e396bcSPaul Traina m.free = t->bt_free;
169f1e396bcSPaul Traina m.nrecs = t->bt_nrecs;
170f1e396bcSPaul Traina m.flags = F_ISSET(t, SAVEMETA);
17158f0484fSRodney W. Grimes
17258f0484fSRodney W. Grimes memmove(p, &m, sizeof(BTMETA));
17358f0484fSRodney W. Grimes mpool_put(t->bt_mp, p, MPOOL_DIRTY);
17458f0484fSRodney W. Grimes return (RET_SUCCESS);
17558f0484fSRodney W. Grimes }
176