Changes since last update:
- Strengthen metadata checking to avoid ASSERTing on bad disk contents - Validate btree records that are being retrieved for clients - Strengthen root inode verification - Convert license blurbs to SPDX tags - Enable changing DAX flag on directories - Fix some writeback deadlocks in reflink - Refactor out some old xfs helpers - Move type verifiers to a separate file - Fix some fuzzer crashes - Various other bug fixes -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEEUzaAxoMeQq6m2jMV+H93GTRKtOsFAlsfUegACgkQ+H93GTRK tOv0sw/9HW63zhuzGs9uihmyGvtqNeeUBfKc+3ovJ80wnhYOa0n8yYCBORS1EaMS YPk74IbD0yAak0H9ePdOpont43gGVTDox6/K8+6rPFnWtX30Z2/ckb6BWE4UfoW8 QeojpB2+aS6fqfO1wcSb3i//XRu4h90ORQY0xNkHYcN4GWwIDwPCyBf+AT9HH1E+ GFHtB3QWANZg6LRT7X0GVgz5r68lzyxX1WisJ4uAm0NwKR5zVb9NWFCcOszQ45Ky +YFw4kfgithbIHlwTpo3LrvQk7+cBhlSpWuASZOYjugxcQ2d85B/+9mF/QDnLOey ddbO6WK+wo0KZImpFvOOQZY07cO7vtWwkWHraz0PkUdaEab5rcnooLoJg9UTMZa4 WT8wM8CrX1kkFvJQCuAMV9jblovjETeYhHfG8ak8Z/lWc3WEnEBUFQiO9ZVQdiAv B02xMmpOkfi0fqRCg6li9u3CJtN+2vxPiNEME3lz5zdY5aE2aXSmCspvP3aPVZMt y1fZ90u5NONz6Q9WrIh0plEru4oynhwVuqRrnVRDPCT4X64IZXuf/fBmYqrfZGmJ K45P/LQDvfcHj3xBLhfkKv5OpXtyYgDtLSBNqYAYrcGS4sW7Z4Ts8ohqcOhF1OqR g3mFp75aO4Ekw6hFbg9CRX13G4mu80BmnRKDVwFjThkl6d0Xyxw= =SD3u -----END PGP SIGNATURE----- Merge tag 'xfs-4.18-merge-10' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux Pull more xfs updates from Darrick Wong: "Here's the second round of patches for XFS for 4.18. Most of the commits are small cleanups, bug fixes, and continued strengthening of metadata verifiers; the bulk of the diff is the conversion of the fs/xfs/ tree to use SPDX tags. This series has been run through a full xfstests run over the weekend and through a quick xfstests run against this morning's master, with no major failures reported. Summary: - Strengthen metadata checking to avoid ASSERTing on bad disk contents - Validate btree records that are being retrieved for clients - Strengthen root inode verification - Convert license blurbs to SPDX tags - Enable changing DAX flag on directories - Fix some writeback deadlocks in reflink - Refactor out some old xfs helpers - Move type verifiers to a separate file - Fix some fuzzer crashes - Various other bug fixes" * tag 'xfs-4.18-merge-10' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux: (31 commits) xfs: update incore per-AG inode count xfs: replace do_mod with native operations xfs: don't call xfs_da_shrink_inode with NULL bp xfs: clean up MIN/MAX xfs: move various type verifiers to common file xfs: xfs_reflink_convert_cow() memory allocation deadlock xfs: setup VFS i_rwsem lockdep state correctly xfs: fix string handling in label get/set functions xfs: convert to SPDX license tags xfs: validate btree records on retrieval xfs: push corruption -> ESTALE conversion to xfs_nfs_get_inode() xfs: verify root inode more thoroughly xfs: verify COW extent size hint is valid in inode verifier xfs: verify extent size hint is valid in inode verifier xfs: catch bad stripe alignment configurations iomap: fsync swap files before iterating mappings xfs: use xfs_trans_getsb in xfs_sync_sb_buf xfs: don't assert on corrupted unlinked inode list xfs: explicitly pass buffer size to xfs_corruption_error xfs: don't assert when on-disk btree pointers are garbage ...
This commit is contained in:
commit
a205f0c974
|
@ -1388,7 +1388,11 @@ int iomap_swapfile_activate(struct swap_info_struct *sis,
|
||||||
loff_t len = ALIGN_DOWN(i_size_read(inode), PAGE_SIZE);
|
loff_t len = ALIGN_DOWN(i_size_read(inode), PAGE_SIZE);
|
||||||
loff_t ret;
|
loff_t ret;
|
||||||
|
|
||||||
ret = filemap_write_and_wait(inode->i_mapping);
|
/*
|
||||||
|
* Persist all file mapping metadata so that we won't have any
|
||||||
|
* IOMAP_F_DIRTY iomaps.
|
||||||
|
*/
|
||||||
|
ret = vfs_fsync(swap_file, 1);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
#
|
#
|
||||||
# Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
# Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
# All Rights Reserved.
|
# All Rights Reserved.
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or
|
|
||||||
# modify it under the terms of the GNU General Public License as
|
|
||||||
# published by the Free Software Foundation.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it would be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write the Free Software Foundation,
|
|
||||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
#
|
|
||||||
|
|
||||||
ccflags-y += -I$(src) # needed for trace events
|
ccflags-y += -I$(src) # needed for trace events
|
||||||
ccflags-y += -I$(src)/libxfs
|
ccflags-y += -I$(src)/libxfs
|
||||||
|
@ -62,6 +50,7 @@ xfs-y += $(addprefix libxfs/, \
|
||||||
xfs_sb.o \
|
xfs_sb.o \
|
||||||
xfs_symlink_remote.o \
|
xfs_symlink_remote.o \
|
||||||
xfs_trans_resv.o \
|
xfs_trans_resv.o \
|
||||||
|
xfs_types.o \
|
||||||
)
|
)
|
||||||
# xfs_rtbitmap is shared with libxfs
|
# xfs_rtbitmap is shared with libxfs
|
||||||
xfs-$(CONFIG_XFS_RT) += $(addprefix libxfs/, \
|
xfs-$(CONFIG_XFS_RT) += $(addprefix libxfs/, \
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
#include <linux/sched/mm.h>
|
#include <linux/sched/mm.h>
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SUPPORT_KMEM_H__
|
#ifndef __XFS_SUPPORT_KMEM_H__
|
||||||
#define __XFS_SUPPORT_KMEM_H__
|
#define __XFS_SUPPORT_KMEM_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_AG_RESV_H__
|
#ifndef __XFS_AG_RESV_H__
|
||||||
#define __XFS_AG_RESV_H__
|
#define __XFS_AG_RESV_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -227,15 +215,37 @@ xfs_alloc_get_rec(
|
||||||
xfs_extlen_t *len, /* output: length of extent */
|
xfs_extlen_t *len, /* output: length of extent */
|
||||||
int *stat) /* output: success/failure */
|
int *stat) /* output: success/failure */
|
||||||
{
|
{
|
||||||
|
struct xfs_mount *mp = cur->bc_mp;
|
||||||
|
xfs_agnumber_t agno = cur->bc_private.a.agno;
|
||||||
union xfs_btree_rec *rec;
|
union xfs_btree_rec *rec;
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
error = xfs_btree_get_rec(cur, &rec, stat);
|
error = xfs_btree_get_rec(cur, &rec, stat);
|
||||||
if (!error && *stat == 1) {
|
if (error || !(*stat))
|
||||||
|
return error;
|
||||||
|
if (rec->alloc.ar_blockcount == 0)
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
*bno = be32_to_cpu(rec->alloc.ar_startblock);
|
*bno = be32_to_cpu(rec->alloc.ar_startblock);
|
||||||
*len = be32_to_cpu(rec->alloc.ar_blockcount);
|
*len = be32_to_cpu(rec->alloc.ar_blockcount);
|
||||||
}
|
|
||||||
return error;
|
/* check for valid extent range, including overflow */
|
||||||
|
if (!xfs_verify_agbno(mp, agno, *bno))
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (*bno > *bno + *len)
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (!xfs_verify_agbno(mp, agno, *bno + *len - 1))
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
out_bad_rec:
|
||||||
|
xfs_warn(mp,
|
||||||
|
"%s Freespace BTree record corruption in AG %d detected!",
|
||||||
|
cur->bc_btnum == XFS_BTNUM_BNO ? "Block" : "Size", agno);
|
||||||
|
xfs_warn(mp,
|
||||||
|
"start block 0x%x block count 0x%x", *bno, *len);
|
||||||
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -3113,55 +3123,6 @@ xfs_alloc_query_all(
|
||||||
return xfs_btree_query_all(cur, xfs_alloc_query_range_helper, &query);
|
return xfs_btree_query_all(cur, xfs_alloc_query_range_helper, &query);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Find the size of the AG, in blocks. */
|
|
||||||
xfs_agblock_t
|
|
||||||
xfs_ag_block_count(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_agnumber_t agno)
|
|
||||||
{
|
|
||||||
ASSERT(agno < mp->m_sb.sb_agcount);
|
|
||||||
|
|
||||||
if (agno < mp->m_sb.sb_agcount - 1)
|
|
||||||
return mp->m_sb.sb_agblocks;
|
|
||||||
return mp->m_sb.sb_dblocks - (agno * mp->m_sb.sb_agblocks);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Verify that an AG block number pointer neither points outside the AG
|
|
||||||
* nor points at static metadata.
|
|
||||||
*/
|
|
||||||
bool
|
|
||||||
xfs_verify_agbno(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_agnumber_t agno,
|
|
||||||
xfs_agblock_t agbno)
|
|
||||||
{
|
|
||||||
xfs_agblock_t eoag;
|
|
||||||
|
|
||||||
eoag = xfs_ag_block_count(mp, agno);
|
|
||||||
if (agbno >= eoag)
|
|
||||||
return false;
|
|
||||||
if (agbno <= XFS_AGFL_BLOCK(mp))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Verify that an FS block number pointer neither points outside the
|
|
||||||
* filesystem nor points at static AG metadata.
|
|
||||||
*/
|
|
||||||
bool
|
|
||||||
xfs_verify_fsbno(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_fsblock_t fsbno)
|
|
||||||
{
|
|
||||||
xfs_agnumber_t agno = XFS_FSB_TO_AGNO(mp, fsbno);
|
|
||||||
|
|
||||||
if (agno >= mp->m_sb.sb_agcount)
|
|
||||||
return false;
|
|
||||||
return xfs_verify_agbno(mp, agno, XFS_FSB_TO_AGBNO(mp, fsbno));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Is there a record covering a given extent? */
|
/* Is there a record covering a given extent? */
|
||||||
int
|
int
|
||||||
xfs_alloc_has_record(
|
xfs_alloc_has_record(
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_ALLOC_H__
|
#ifndef __XFS_ALLOC_H__
|
||||||
#define __XFS_ALLOC_H__
|
#define __XFS_ALLOC_H__
|
||||||
|
@ -254,10 +242,6 @@ int xfs_alloc_query_range(struct xfs_btree_cur *cur,
|
||||||
xfs_alloc_query_range_fn fn, void *priv);
|
xfs_alloc_query_range_fn fn, void *priv);
|
||||||
int xfs_alloc_query_all(struct xfs_btree_cur *cur, xfs_alloc_query_range_fn fn,
|
int xfs_alloc_query_all(struct xfs_btree_cur *cur, xfs_alloc_query_range_fn fn,
|
||||||
void *priv);
|
void *priv);
|
||||||
xfs_agblock_t xfs_ag_block_count(struct xfs_mount *mp, xfs_agnumber_t agno);
|
|
||||||
bool xfs_verify_agbno(struct xfs_mount *mp, xfs_agnumber_t agno,
|
|
||||||
xfs_agblock_t agbno);
|
|
||||||
bool xfs_verify_fsbno(struct xfs_mount *mp, xfs_fsblock_t fsbno);
|
|
||||||
|
|
||||||
int xfs_alloc_has_record(struct xfs_btree_cur *cur, xfs_agblock_t bno,
|
int xfs_alloc_has_record(struct xfs_btree_cur *cur, xfs_agblock_t bno,
|
||||||
xfs_extlen_t len, bool *exist);
|
xfs_extlen_t len, bool *exist);
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -242,7 +230,6 @@ xfs_allocbt_init_ptr_from_cur(
|
||||||
struct xfs_agf *agf = XFS_BUF_TO_AGF(cur->bc_private.a.agbp);
|
struct xfs_agf *agf = XFS_BUF_TO_AGF(cur->bc_private.a.agbp);
|
||||||
|
|
||||||
ASSERT(cur->bc_private.a.agno == be32_to_cpu(agf->agf_seqno));
|
ASSERT(cur->bc_private.a.agno == be32_to_cpu(agf->agf_seqno));
|
||||||
ASSERT(agf->agf_roots[cur->bc_btnum] != 0);
|
|
||||||
|
|
||||||
ptr->s = agf->agf_roots[cur->bc_btnum];
|
ptr->s = agf->agf_roots[cur->bc_btnum];
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_ALLOC_BTREE_H__
|
#ifndef __XFS_ALLOC_BTREE_H__
|
||||||
#define __XFS_ALLOC_BTREE_H__
|
#define __XFS_ALLOC_BTREE_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -477,7 +465,7 @@ xfs_attr_shortform_bytesfit(xfs_inode_t *dp, int bytes)
|
||||||
* A data fork btree root must have space for at least
|
* A data fork btree root must have space for at least
|
||||||
* MINDBTPTRS key/ptr pairs if the data fork is small or empty.
|
* MINDBTPTRS key/ptr pairs if the data fork is small or empty.
|
||||||
*/
|
*/
|
||||||
minforkoff = MAX(dsize, XFS_BMDR_SPACE_CALC(MINDBTPTRS));
|
minforkoff = max(dsize, XFS_BMDR_SPACE_CALC(MINDBTPTRS));
|
||||||
minforkoff = roundup(minforkoff, 8) >> 3;
|
minforkoff = roundup(minforkoff, 8) >> 3;
|
||||||
|
|
||||||
/* attr fork btree root can have at least this many key/ptr pairs */
|
/* attr fork btree root can have at least this many key/ptr pairs */
|
||||||
|
@ -803,9 +791,8 @@ xfs_attr_shortform_to_leaf(
|
||||||
ASSERT(blkno == 0);
|
ASSERT(blkno == 0);
|
||||||
error = xfs_attr3_leaf_create(args, blkno, &bp);
|
error = xfs_attr3_leaf_create(args, blkno, &bp);
|
||||||
if (error) {
|
if (error) {
|
||||||
error = xfs_da_shrink_inode(args, 0, bp);
|
/* xfs_attr3_leaf_create may not have instantiated a block */
|
||||||
bp = NULL;
|
if (bp && (xfs_da_shrink_inode(args, 0, bp) != 0))
|
||||||
if (error)
|
|
||||||
goto out;
|
goto out;
|
||||||
xfs_idata_realloc(dp, size, XFS_ATTR_FORK); /* try to put */
|
xfs_idata_realloc(dp, size, XFS_ATTR_FORK); /* try to put */
|
||||||
memcpy(ifp->if_u1.if_data, tmpbuffer, size); /* it back */
|
memcpy(ifp->if_u1.if_data, tmpbuffer, size); /* it back */
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2002-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2002-2003,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_ATTR_LEAF_H__
|
#ifndef __XFS_ATTR_LEAF_H__
|
||||||
#define __XFS_ATTR_LEAF_H__
|
#define __XFS_ATTR_LEAF_H__
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_ATTR_REMOTE_H__
|
#ifndef __XFS_ATTR_REMOTE_H__
|
||||||
#define __XFS_ATTR_REMOTE_H__
|
#define __XFS_ATTR_REMOTE_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_ATTR_SF_H__
|
#ifndef __XFS_ATTR_SF_H__
|
||||||
#define __XFS_ATTR_SF_H__
|
#define __XFS_ATTR_SF_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_log_format.h"
|
#include "xfs_log_format.h"
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_BIT_H__
|
#ifndef __XFS_BIT_H__
|
||||||
#define __XFS_BIT_H__
|
#define __XFS_BIT_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -1248,7 +1236,6 @@ xfs_iread_extents(
|
||||||
|
|
||||||
num_recs = xfs_btree_get_numrecs(block);
|
num_recs = xfs_btree_get_numrecs(block);
|
||||||
if (unlikely(i + num_recs > nextents)) {
|
if (unlikely(i + num_recs > nextents)) {
|
||||||
ASSERT(i + num_recs <= nextents);
|
|
||||||
xfs_warn(ip->i_mount,
|
xfs_warn(ip->i_mount,
|
||||||
"corrupt dinode %Lu, (btree extents).",
|
"corrupt dinode %Lu, (btree extents).",
|
||||||
(unsigned long long) ip->i_ino);
|
(unsigned long long) ip->i_ino);
|
||||||
|
@ -2936,7 +2923,7 @@ xfs_bmap_extsize_align(
|
||||||
* perform this alignment, or if a truncate shot us in the
|
* perform this alignment, or if a truncate shot us in the
|
||||||
* foot.
|
* foot.
|
||||||
*/
|
*/
|
||||||
temp = do_mod(orig_off, extsz);
|
div_u64_rem(orig_off, extsz, &temp);
|
||||||
if (temp) {
|
if (temp) {
|
||||||
align_alen += temp;
|
align_alen += temp;
|
||||||
align_off -= temp;
|
align_off -= temp;
|
||||||
|
@ -3480,7 +3467,7 @@ xfs_bmap_btalloc(
|
||||||
xfs_rmap_skip_owner_update(&args.oinfo);
|
xfs_rmap_skip_owner_update(&args.oinfo);
|
||||||
|
|
||||||
/* Trim the allocation back to the maximum an AG can fit. */
|
/* Trim the allocation back to the maximum an AG can fit. */
|
||||||
args.maxlen = MIN(ap->length, mp->m_ag_max_usable);
|
args.maxlen = min(ap->length, mp->m_ag_max_usable);
|
||||||
args.firstblock = *ap->firstblock;
|
args.firstblock = *ap->firstblock;
|
||||||
blen = 0;
|
blen = 0;
|
||||||
if (nullfb) {
|
if (nullfb) {
|
||||||
|
@ -3510,15 +3497,17 @@ xfs_bmap_btalloc(
|
||||||
/* apply extent size hints if obtained earlier */
|
/* apply extent size hints if obtained earlier */
|
||||||
if (align) {
|
if (align) {
|
||||||
args.prod = align;
|
args.prod = align;
|
||||||
if ((args.mod = (xfs_extlen_t)do_mod(ap->offset, args.prod)))
|
div_u64_rem(ap->offset, args.prod, &args.mod);
|
||||||
args.mod = (xfs_extlen_t)(args.prod - args.mod);
|
if (args.mod)
|
||||||
|
args.mod = args.prod - args.mod;
|
||||||
} else if (mp->m_sb.sb_blocksize >= PAGE_SIZE) {
|
} else if (mp->m_sb.sb_blocksize >= PAGE_SIZE) {
|
||||||
args.prod = 1;
|
args.prod = 1;
|
||||||
args.mod = 0;
|
args.mod = 0;
|
||||||
} else {
|
} else {
|
||||||
args.prod = PAGE_SIZE >> mp->m_sb.sb_blocklog;
|
args.prod = PAGE_SIZE >> mp->m_sb.sb_blocklog;
|
||||||
if ((args.mod = (xfs_extlen_t)(do_mod(ap->offset, args.prod))))
|
div_u64_rem(ap->offset, args.prod, &args.mod);
|
||||||
args.mod = (xfs_extlen_t)(args.prod - args.mod);
|
if (args.mod)
|
||||||
|
args.mod = args.prod - args.mod;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
* If we are not low on available data blocks, and the
|
* If we are not low on available data blocks, and the
|
||||||
|
@ -4966,13 +4955,15 @@ xfs_bmap_del_extent_real(
|
||||||
if (whichfork == XFS_DATA_FORK && XFS_IS_REALTIME_INODE(ip)) {
|
if (whichfork == XFS_DATA_FORK && XFS_IS_REALTIME_INODE(ip)) {
|
||||||
xfs_fsblock_t bno;
|
xfs_fsblock_t bno;
|
||||||
xfs_filblks_t len;
|
xfs_filblks_t len;
|
||||||
|
xfs_extlen_t mod;
|
||||||
|
|
||||||
|
bno = div_u64_rem(del->br_startblock, mp->m_sb.sb_rextsize,
|
||||||
|
&mod);
|
||||||
|
ASSERT(mod == 0);
|
||||||
|
len = div_u64_rem(del->br_blockcount, mp->m_sb.sb_rextsize,
|
||||||
|
&mod);
|
||||||
|
ASSERT(mod == 0);
|
||||||
|
|
||||||
ASSERT(do_mod(del->br_blockcount, mp->m_sb.sb_rextsize) == 0);
|
|
||||||
ASSERT(do_mod(del->br_startblock, mp->m_sb.sb_rextsize) == 0);
|
|
||||||
bno = del->br_startblock;
|
|
||||||
len = del->br_blockcount;
|
|
||||||
do_div(bno, mp->m_sb.sb_rextsize);
|
|
||||||
do_div(len, mp->m_sb.sb_rextsize);
|
|
||||||
error = xfs_rtfree_extent(tp, bno, (xfs_extlen_t)len);
|
error = xfs_rtfree_extent(tp, bno, (xfs_extlen_t)len);
|
||||||
if (error)
|
if (error)
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -5309,9 +5300,12 @@ __xfs_bunmapi(
|
||||||
del.br_blockcount = max_len;
|
del.br_blockcount = max_len;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!isrt)
|
||||||
|
goto delete;
|
||||||
|
|
||||||
sum = del.br_startblock + del.br_blockcount;
|
sum = del.br_startblock + del.br_blockcount;
|
||||||
if (isrt &&
|
div_u64_rem(sum, mp->m_sb.sb_rextsize, &mod);
|
||||||
(mod = do_mod(sum, mp->m_sb.sb_rextsize))) {
|
if (mod) {
|
||||||
/*
|
/*
|
||||||
* Realtime extent not lined up at the end.
|
* Realtime extent not lined up at the end.
|
||||||
* The extent could have been split into written
|
* The extent could have been split into written
|
||||||
|
@ -5358,7 +5352,8 @@ __xfs_bunmapi(
|
||||||
goto error0;
|
goto error0;
|
||||||
goto nodelete;
|
goto nodelete;
|
||||||
}
|
}
|
||||||
if (isrt && (mod = do_mod(del.br_startblock, mp->m_sb.sb_rextsize))) {
|
div_u64_rem(del.br_startblock, mp->m_sb.sb_rextsize, &mod);
|
||||||
|
if (mod) {
|
||||||
/*
|
/*
|
||||||
* Realtime extent is lined up at the end but not
|
* Realtime extent is lined up at the end but not
|
||||||
* at the front. We'll get rid of full extents if
|
* at the front. We'll get rid of full extents if
|
||||||
|
@ -5427,6 +5422,7 @@ __xfs_bunmapi(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
delete:
|
||||||
if (wasdel) {
|
if (wasdel) {
|
||||||
error = xfs_bmap_del_extent_delay(ip, whichfork, &icur,
|
error = xfs_bmap_del_extent_delay(ip, whichfork, &icur,
|
||||||
&got, &del);
|
&got, &del);
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_BMAP_H__
|
#ifndef __XFS_BMAP_H__
|
||||||
#define __XFS_BMAP_H__
|
#define __XFS_BMAP_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2002-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2002-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_BMAP_BTREE_H__
|
#ifndef __XFS_BMAP_BTREE_H__
|
||||||
#define __XFS_BMAP_BTREE_H__
|
#define __XFS_BMAP_BTREE_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -234,7 +222,6 @@ xfs_btree_check_sptr(
|
||||||
return xfs_verify_agbno(cur->bc_mp, cur->bc_private.a.agno, agbno);
|
return xfs_verify_agbno(cur->bc_mp, cur->bc_private.a.agno, agbno);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
/*
|
/*
|
||||||
* Check that a given (indexed) btree pointer at a certain level of a
|
* Check that a given (indexed) btree pointer at a certain level of a
|
||||||
* btree is valid and doesn't point past where it should.
|
* btree is valid and doesn't point past where it should.
|
||||||
|
@ -247,17 +234,31 @@ xfs_btree_check_ptr(
|
||||||
int level)
|
int level)
|
||||||
{
|
{
|
||||||
if (cur->bc_flags & XFS_BTREE_LONG_PTRS) {
|
if (cur->bc_flags & XFS_BTREE_LONG_PTRS) {
|
||||||
XFS_WANT_CORRUPTED_RETURN(cur->bc_mp,
|
if (xfs_btree_check_lptr(cur, be64_to_cpu((&ptr->l)[index]),
|
||||||
xfs_btree_check_lptr(cur,
|
level))
|
||||||
be64_to_cpu((&ptr->l)[index]), level));
|
return 0;
|
||||||
|
xfs_err(cur->bc_mp,
|
||||||
|
"Inode %llu fork %d: Corrupt btree %d pointer at level %d index %d.",
|
||||||
|
cur->bc_private.b.ip->i_ino,
|
||||||
|
cur->bc_private.b.whichfork, cur->bc_btnum,
|
||||||
|
level, index);
|
||||||
} else {
|
} else {
|
||||||
XFS_WANT_CORRUPTED_RETURN(cur->bc_mp,
|
if (xfs_btree_check_sptr(cur, be32_to_cpu((&ptr->s)[index]),
|
||||||
xfs_btree_check_sptr(cur,
|
level))
|
||||||
be32_to_cpu((&ptr->s)[index]), level));
|
return 0;
|
||||||
|
xfs_err(cur->bc_mp,
|
||||||
|
"AG %u: Corrupt btree %d pointer at level %d index %d.",
|
||||||
|
cur->bc_private.a.agno, cur->bc_btnum,
|
||||||
|
level, index);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
# define xfs_btree_debug_check_ptr xfs_btree_check_ptr
|
||||||
|
#else
|
||||||
|
# define xfs_btree_debug_check_ptr(...) (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -988,22 +989,30 @@ xfs_btree_readahead(
|
||||||
return xfs_btree_readahead_sblock(cur, lr, block);
|
return xfs_btree_readahead_sblock(cur, lr, block);
|
||||||
}
|
}
|
||||||
|
|
||||||
STATIC xfs_daddr_t
|
STATIC int
|
||||||
xfs_btree_ptr_to_daddr(
|
xfs_btree_ptr_to_daddr(
|
||||||
struct xfs_btree_cur *cur,
|
struct xfs_btree_cur *cur,
|
||||||
union xfs_btree_ptr *ptr)
|
union xfs_btree_ptr *ptr,
|
||||||
|
xfs_daddr_t *daddr)
|
||||||
{
|
{
|
||||||
|
xfs_fsblock_t fsbno;
|
||||||
|
xfs_agblock_t agbno;
|
||||||
|
int error;
|
||||||
|
|
||||||
|
error = xfs_btree_check_ptr(cur, ptr, 0, 1);
|
||||||
|
if (error)
|
||||||
|
return error;
|
||||||
|
|
||||||
if (cur->bc_flags & XFS_BTREE_LONG_PTRS) {
|
if (cur->bc_flags & XFS_BTREE_LONG_PTRS) {
|
||||||
ASSERT(ptr->l != cpu_to_be64(NULLFSBLOCK));
|
fsbno = be64_to_cpu(ptr->l);
|
||||||
|
*daddr = XFS_FSB_TO_DADDR(cur->bc_mp, fsbno);
|
||||||
return XFS_FSB_TO_DADDR(cur->bc_mp, be64_to_cpu(ptr->l));
|
|
||||||
} else {
|
} else {
|
||||||
ASSERT(cur->bc_private.a.agno != NULLAGNUMBER);
|
agbno = be32_to_cpu(ptr->s);
|
||||||
ASSERT(ptr->s != cpu_to_be32(NULLAGBLOCK));
|
*daddr = XFS_AGB_TO_DADDR(cur->bc_mp, cur->bc_private.a.agno,
|
||||||
|
agbno);
|
||||||
return XFS_AGB_TO_DADDR(cur->bc_mp, cur->bc_private.a.agno,
|
|
||||||
be32_to_cpu(ptr->s));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1018,8 +1027,11 @@ xfs_btree_readahead_ptr(
|
||||||
union xfs_btree_ptr *ptr,
|
union xfs_btree_ptr *ptr,
|
||||||
xfs_extlen_t count)
|
xfs_extlen_t count)
|
||||||
{
|
{
|
||||||
xfs_buf_readahead(cur->bc_mp->m_ddev_targp,
|
xfs_daddr_t daddr;
|
||||||
xfs_btree_ptr_to_daddr(cur, ptr),
|
|
||||||
|
if (xfs_btree_ptr_to_daddr(cur, ptr, &daddr))
|
||||||
|
return;
|
||||||
|
xfs_buf_readahead(cur->bc_mp->m_ddev_targp, daddr,
|
||||||
cur->bc_mp->m_bsize * count, cur->bc_ops->buf_ops);
|
cur->bc_mp->m_bsize * count, cur->bc_ops->buf_ops);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1282,11 +1294,14 @@ xfs_btree_get_buf_block(
|
||||||
{
|
{
|
||||||
struct xfs_mount *mp = cur->bc_mp;
|
struct xfs_mount *mp = cur->bc_mp;
|
||||||
xfs_daddr_t d;
|
xfs_daddr_t d;
|
||||||
|
int error;
|
||||||
|
|
||||||
/* need to sort out how callers deal with failures first */
|
/* need to sort out how callers deal with failures first */
|
||||||
ASSERT(!(flags & XBF_TRYLOCK));
|
ASSERT(!(flags & XBF_TRYLOCK));
|
||||||
|
|
||||||
d = xfs_btree_ptr_to_daddr(cur, ptr);
|
error = xfs_btree_ptr_to_daddr(cur, ptr, &d);
|
||||||
|
if (error)
|
||||||
|
return error;
|
||||||
*bpp = xfs_trans_get_buf(cur->bc_tp, mp->m_ddev_targp, d,
|
*bpp = xfs_trans_get_buf(cur->bc_tp, mp->m_ddev_targp, d,
|
||||||
mp->m_bsize, flags);
|
mp->m_bsize, flags);
|
||||||
|
|
||||||
|
@ -1317,7 +1332,9 @@ xfs_btree_read_buf_block(
|
||||||
/* need to sort out how callers deal with failures first */
|
/* need to sort out how callers deal with failures first */
|
||||||
ASSERT(!(flags & XBF_TRYLOCK));
|
ASSERT(!(flags & XBF_TRYLOCK));
|
||||||
|
|
||||||
d = xfs_btree_ptr_to_daddr(cur, ptr);
|
error = xfs_btree_ptr_to_daddr(cur, ptr, &d);
|
||||||
|
if (error)
|
||||||
|
return error;
|
||||||
error = xfs_trans_read_buf(mp, cur->bc_tp, mp->m_ddev_targp, d,
|
error = xfs_trans_read_buf(mp, cur->bc_tp, mp->m_ddev_targp, d,
|
||||||
mp->m_bsize, flags, bpp,
|
mp->m_bsize, flags, bpp,
|
||||||
cur->bc_ops->buf_ops);
|
cur->bc_ops->buf_ops);
|
||||||
|
@ -1764,6 +1781,7 @@ xfs_btree_lookup_get_block(
|
||||||
struct xfs_btree_block **blkp) /* return btree block */
|
struct xfs_btree_block **blkp) /* return btree block */
|
||||||
{
|
{
|
||||||
struct xfs_buf *bp; /* buffer pointer for btree block */
|
struct xfs_buf *bp; /* buffer pointer for btree block */
|
||||||
|
xfs_daddr_t daddr;
|
||||||
int error = 0;
|
int error = 0;
|
||||||
|
|
||||||
/* special case the root block if in an inode */
|
/* special case the root block if in an inode */
|
||||||
|
@ -1780,7 +1798,10 @@ xfs_btree_lookup_get_block(
|
||||||
* Otherwise throw it away and get a new one.
|
* Otherwise throw it away and get a new one.
|
||||||
*/
|
*/
|
||||||
bp = cur->bc_bufs[level];
|
bp = cur->bc_bufs[level];
|
||||||
if (bp && XFS_BUF_ADDR(bp) == xfs_btree_ptr_to_daddr(cur, pp)) {
|
error = xfs_btree_ptr_to_daddr(cur, pp, &daddr);
|
||||||
|
if (error)
|
||||||
|
return error;
|
||||||
|
if (bp && XFS_BUF_ADDR(bp) == daddr) {
|
||||||
*blkp = XFS_BUF_TO_BLOCK(bp);
|
*blkp = XFS_BUF_TO_BLOCK(bp);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -1896,7 +1917,13 @@ xfs_btree_lookup(
|
||||||
high = xfs_btree_get_numrecs(block);
|
high = xfs_btree_get_numrecs(block);
|
||||||
if (!high) {
|
if (!high) {
|
||||||
/* Block is empty, must be an empty leaf. */
|
/* Block is empty, must be an empty leaf. */
|
||||||
ASSERT(level == 0 && cur->bc_nlevels == 1);
|
if (level != 0 || cur->bc_nlevels != 1) {
|
||||||
|
XFS_CORRUPTION_ERROR(__func__,
|
||||||
|
XFS_ERRLEVEL_LOW,
|
||||||
|
cur->bc_mp, block,
|
||||||
|
sizeof(*block));
|
||||||
|
return -EFSCORRUPTED;
|
||||||
|
}
|
||||||
|
|
||||||
cur->bc_ptrs[0] = dir != XFS_LOOKUP_LE;
|
cur->bc_ptrs[0] = dir != XFS_LOOKUP_LE;
|
||||||
*stat = 0;
|
*stat = 0;
|
||||||
|
@ -1946,11 +1973,10 @@ xfs_btree_lookup(
|
||||||
keyno = 1;
|
keyno = 1;
|
||||||
pp = xfs_btree_ptr_addr(cur, keyno, block);
|
pp = xfs_btree_ptr_addr(cur, keyno, block);
|
||||||
|
|
||||||
#ifdef DEBUG
|
error = xfs_btree_debug_check_ptr(cur, pp, 0, level);
|
||||||
error = xfs_btree_check_ptr(cur, pp, 0, level);
|
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
#endif
|
|
||||||
cur->bc_ptrs[level] = keyno;
|
cur->bc_ptrs[level] = keyno;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2354,11 +2380,11 @@ xfs_btree_lshift(
|
||||||
|
|
||||||
lpp = xfs_btree_ptr_addr(cur, lrecs, left);
|
lpp = xfs_btree_ptr_addr(cur, lrecs, left);
|
||||||
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
||||||
#ifdef DEBUG
|
|
||||||
error = xfs_btree_check_ptr(cur, rpp, 0, level);
|
error = xfs_btree_debug_check_ptr(cur, rpp, 0, level);
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
#endif
|
|
||||||
xfs_btree_copy_keys(cur, lkp, rkp, 1);
|
xfs_btree_copy_keys(cur, lkp, rkp, 1);
|
||||||
xfs_btree_copy_ptrs(cur, lpp, rpp, 1);
|
xfs_btree_copy_ptrs(cur, lpp, rpp, 1);
|
||||||
|
|
||||||
|
@ -2393,15 +2419,14 @@ xfs_btree_lshift(
|
||||||
XFS_BTREE_STATS_ADD(cur, moves, rrecs - 1);
|
XFS_BTREE_STATS_ADD(cur, moves, rrecs - 1);
|
||||||
if (level > 0) {
|
if (level > 0) {
|
||||||
/* It's a nonleaf. operate on keys and ptrs */
|
/* It's a nonleaf. operate on keys and ptrs */
|
||||||
#ifdef DEBUG
|
|
||||||
int i; /* loop index */
|
int i; /* loop index */
|
||||||
|
|
||||||
for (i = 0; i < rrecs; i++) {
|
for (i = 0; i < rrecs; i++) {
|
||||||
error = xfs_btree_check_ptr(cur, rpp, i + 1, level);
|
error = xfs_btree_debug_check_ptr(cur, rpp, i + 1, level);
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
xfs_btree_shift_keys(cur,
|
xfs_btree_shift_keys(cur,
|
||||||
xfs_btree_key_addr(cur, 2, right),
|
xfs_btree_key_addr(cur, 2, right),
|
||||||
-1, rrecs);
|
-1, rrecs);
|
||||||
|
@ -2541,22 +2566,18 @@ xfs_btree_rshift(
|
||||||
rkp = xfs_btree_key_addr(cur, 1, right);
|
rkp = xfs_btree_key_addr(cur, 1, right);
|
||||||
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
for (i = rrecs - 1; i >= 0; i--) {
|
for (i = rrecs - 1; i >= 0; i--) {
|
||||||
error = xfs_btree_check_ptr(cur, rpp, i, level);
|
error = xfs_btree_debug_check_ptr(cur, rpp, i, level);
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
xfs_btree_shift_keys(cur, rkp, 1, rrecs);
|
xfs_btree_shift_keys(cur, rkp, 1, rrecs);
|
||||||
xfs_btree_shift_ptrs(cur, rpp, 1, rrecs);
|
xfs_btree_shift_ptrs(cur, rpp, 1, rrecs);
|
||||||
|
|
||||||
#ifdef DEBUG
|
error = xfs_btree_debug_check_ptr(cur, lpp, 0, level);
|
||||||
error = xfs_btree_check_ptr(cur, lpp, 0, level);
|
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Now put the new data in, and log it. */
|
/* Now put the new data in, and log it. */
|
||||||
xfs_btree_copy_keys(cur, rkp, lkp, 1);
|
xfs_btree_copy_keys(cur, rkp, lkp, 1);
|
||||||
|
@ -2661,9 +2682,7 @@ __xfs_btree_split(
|
||||||
int rrecs;
|
int rrecs;
|
||||||
int src_index;
|
int src_index;
|
||||||
int error; /* error return value */
|
int error; /* error return value */
|
||||||
#ifdef DEBUG
|
|
||||||
int i;
|
int i;
|
||||||
#endif
|
|
||||||
|
|
||||||
XFS_BTREE_STATS_INC(cur, split);
|
XFS_BTREE_STATS_INC(cur, split);
|
||||||
|
|
||||||
|
@ -2729,13 +2748,11 @@ __xfs_btree_split(
|
||||||
rkp = xfs_btree_key_addr(cur, 1, right);
|
rkp = xfs_btree_key_addr(cur, 1, right);
|
||||||
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
for (i = src_index; i < rrecs; i++) {
|
for (i = src_index; i < rrecs; i++) {
|
||||||
error = xfs_btree_check_ptr(cur, lpp, i, level);
|
error = xfs_btree_debug_check_ptr(cur, lpp, i, level);
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Copy the keys & pointers to the new block. */
|
/* Copy the keys & pointers to the new block. */
|
||||||
xfs_btree_copy_keys(cur, rkp, lkp, rrecs);
|
xfs_btree_copy_keys(cur, rkp, lkp, rrecs);
|
||||||
|
@ -2923,9 +2940,7 @@ xfs_btree_new_iroot(
|
||||||
union xfs_btree_ptr nptr; /* new block addr */
|
union xfs_btree_ptr nptr; /* new block addr */
|
||||||
int level; /* btree level */
|
int level; /* btree level */
|
||||||
int error; /* error return code */
|
int error; /* error return code */
|
||||||
#ifdef DEBUG
|
|
||||||
int i; /* loop counter */
|
int i; /* loop counter */
|
||||||
#endif
|
|
||||||
|
|
||||||
XFS_BTREE_STATS_INC(cur, newroot);
|
XFS_BTREE_STATS_INC(cur, newroot);
|
||||||
|
|
||||||
|
@ -2972,20 +2987,18 @@ xfs_btree_new_iroot(
|
||||||
xfs_btree_copy_keys(cur, ckp, kp, xfs_btree_get_numrecs(cblock));
|
xfs_btree_copy_keys(cur, ckp, kp, xfs_btree_get_numrecs(cblock));
|
||||||
|
|
||||||
cpp = xfs_btree_ptr_addr(cur, 1, cblock);
|
cpp = xfs_btree_ptr_addr(cur, 1, cblock);
|
||||||
#ifdef DEBUG
|
|
||||||
for (i = 0; i < be16_to_cpu(cblock->bb_numrecs); i++) {
|
for (i = 0; i < be16_to_cpu(cblock->bb_numrecs); i++) {
|
||||||
error = xfs_btree_check_ptr(cur, pp, i, level);
|
error = xfs_btree_debug_check_ptr(cur, pp, i, level);
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
xfs_btree_copy_ptrs(cur, cpp, pp, xfs_btree_get_numrecs(cblock));
|
xfs_btree_copy_ptrs(cur, cpp, pp, xfs_btree_get_numrecs(cblock));
|
||||||
|
|
||||||
#ifdef DEBUG
|
error = xfs_btree_debug_check_ptr(cur, &nptr, 0, level);
|
||||||
error = xfs_btree_check_ptr(cur, &nptr, 0, level);
|
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
#endif
|
|
||||||
xfs_btree_copy_ptrs(cur, pp, &nptr, 1);
|
xfs_btree_copy_ptrs(cur, pp, &nptr, 1);
|
||||||
|
|
||||||
xfs_iroot_realloc(cur->bc_private.b.ip,
|
xfs_iroot_realloc(cur->bc_private.b.ip,
|
||||||
|
@ -3229,9 +3242,7 @@ xfs_btree_insrec(
|
||||||
int ptr; /* key/record index */
|
int ptr; /* key/record index */
|
||||||
int numrecs;/* number of records */
|
int numrecs;/* number of records */
|
||||||
int error; /* error return value */
|
int error; /* error return value */
|
||||||
#ifdef DEBUG
|
|
||||||
int i;
|
int i;
|
||||||
#endif
|
|
||||||
xfs_daddr_t old_bn;
|
xfs_daddr_t old_bn;
|
||||||
|
|
||||||
ncur = NULL;
|
ncur = NULL;
|
||||||
|
@ -3321,22 +3332,18 @@ xfs_btree_insrec(
|
||||||
kp = xfs_btree_key_addr(cur, ptr, block);
|
kp = xfs_btree_key_addr(cur, ptr, block);
|
||||||
pp = xfs_btree_ptr_addr(cur, ptr, block);
|
pp = xfs_btree_ptr_addr(cur, ptr, block);
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
for (i = numrecs - ptr; i >= 0; i--) {
|
for (i = numrecs - ptr; i >= 0; i--) {
|
||||||
error = xfs_btree_check_ptr(cur, pp, i, level);
|
error = xfs_btree_debug_check_ptr(cur, pp, i, level);
|
||||||
if (error)
|
if (error)
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
xfs_btree_shift_keys(cur, kp, 1, numrecs - ptr + 1);
|
xfs_btree_shift_keys(cur, kp, 1, numrecs - ptr + 1);
|
||||||
xfs_btree_shift_ptrs(cur, pp, 1, numrecs - ptr + 1);
|
xfs_btree_shift_ptrs(cur, pp, 1, numrecs - ptr + 1);
|
||||||
|
|
||||||
#ifdef DEBUG
|
error = xfs_btree_debug_check_ptr(cur, ptrp, 0, level);
|
||||||
error = xfs_btree_check_ptr(cur, ptrp, 0, level);
|
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Now put the new data in, bump numrecs and log it. */
|
/* Now put the new data in, bump numrecs and log it. */
|
||||||
xfs_btree_copy_keys(cur, kp, key, 1);
|
xfs_btree_copy_keys(cur, kp, key, 1);
|
||||||
|
@ -3524,8 +3531,8 @@ xfs_btree_kill_iroot(
|
||||||
int error;
|
int error;
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
union xfs_btree_ptr ptr;
|
union xfs_btree_ptr ptr;
|
||||||
int i;
|
|
||||||
#endif
|
#endif
|
||||||
|
int i;
|
||||||
|
|
||||||
ASSERT(cur->bc_flags & XFS_BTREE_ROOT_IN_INODE);
|
ASSERT(cur->bc_flags & XFS_BTREE_ROOT_IN_INODE);
|
||||||
ASSERT(cur->bc_nlevels > 1);
|
ASSERT(cur->bc_nlevels > 1);
|
||||||
|
@ -3581,13 +3588,13 @@ xfs_btree_kill_iroot(
|
||||||
|
|
||||||
pp = xfs_btree_ptr_addr(cur, 1, block);
|
pp = xfs_btree_ptr_addr(cur, 1, block);
|
||||||
cpp = xfs_btree_ptr_addr(cur, 1, cblock);
|
cpp = xfs_btree_ptr_addr(cur, 1, cblock);
|
||||||
#ifdef DEBUG
|
|
||||||
for (i = 0; i < numrecs; i++) {
|
for (i = 0; i < numrecs; i++) {
|
||||||
error = xfs_btree_check_ptr(cur, cpp, i, level - 1);
|
error = xfs_btree_debug_check_ptr(cur, cpp, i, level - 1);
|
||||||
if (error)
|
if (error)
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
xfs_btree_copy_ptrs(cur, pp, cpp, numrecs);
|
xfs_btree_copy_ptrs(cur, pp, cpp, numrecs);
|
||||||
|
|
||||||
error = xfs_btree_free_block(cur, cbp);
|
error = xfs_btree_free_block(cur, cbp);
|
||||||
|
@ -3721,13 +3728,11 @@ xfs_btree_delrec(
|
||||||
lkp = xfs_btree_key_addr(cur, ptr + 1, block);
|
lkp = xfs_btree_key_addr(cur, ptr + 1, block);
|
||||||
lpp = xfs_btree_ptr_addr(cur, ptr + 1, block);
|
lpp = xfs_btree_ptr_addr(cur, ptr + 1, block);
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
for (i = 0; i < numrecs - ptr; i++) {
|
for (i = 0; i < numrecs - ptr; i++) {
|
||||||
error = xfs_btree_check_ptr(cur, lpp, i, level);
|
error = xfs_btree_debug_check_ptr(cur, lpp, i, level);
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
if (ptr < numrecs) {
|
if (ptr < numrecs) {
|
||||||
xfs_btree_shift_keys(cur, lkp, -1, numrecs - ptr);
|
xfs_btree_shift_keys(cur, lkp, -1, numrecs - ptr);
|
||||||
|
@ -4060,13 +4065,13 @@ xfs_btree_delrec(
|
||||||
lpp = xfs_btree_ptr_addr(cur, lrecs + 1, left);
|
lpp = xfs_btree_ptr_addr(cur, lrecs + 1, left);
|
||||||
rkp = xfs_btree_key_addr(cur, 1, right);
|
rkp = xfs_btree_key_addr(cur, 1, right);
|
||||||
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
rpp = xfs_btree_ptr_addr(cur, 1, right);
|
||||||
#ifdef DEBUG
|
|
||||||
for (i = 1; i < rrecs; i++) {
|
for (i = 1; i < rrecs; i++) {
|
||||||
error = xfs_btree_check_ptr(cur, rpp, i, level);
|
error = xfs_btree_debug_check_ptr(cur, rpp, i, level);
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
xfs_btree_copy_keys(cur, lkp, rkp, rrecs);
|
xfs_btree_copy_keys(cur, lkp, rkp, rrecs);
|
||||||
xfs_btree_copy_ptrs(cur, lpp, rpp, rrecs);
|
xfs_btree_copy_ptrs(cur, lpp, rpp, rrecs);
|
||||||
|
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_BTREE_H__
|
#ifndef __XFS_BTREE_H__
|
||||||
#define __XFS_BTREE_H__
|
#define __XFS_BTREE_H__
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -305,9 +293,11 @@ xfs_da3_node_read(
|
||||||
type = XFS_BLFT_DIR_LEAFN_BUF;
|
type = XFS_BLFT_DIR_LEAFN_BUF;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
type = 0;
|
XFS_CORRUPTION_ERROR(__func__, XFS_ERRLEVEL_LOW,
|
||||||
ASSERT(0);
|
tp->t_mountp, info, sizeof(*info));
|
||||||
break;
|
xfs_trans_brelse(tp, *bpp);
|
||||||
|
*bpp = NULL;
|
||||||
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
xfs_trans_buf_set_type(tp, *bpp, type);
|
xfs_trans_buf_set_type(tp, *bpp, type);
|
||||||
}
|
}
|
||||||
|
@ -2091,7 +2081,7 @@ xfs_da_grow_inode_int(
|
||||||
*/
|
*/
|
||||||
mapp = kmem_alloc(sizeof(*mapp) * count, KM_SLEEP);
|
mapp = kmem_alloc(sizeof(*mapp) * count, KM_SLEEP);
|
||||||
for (b = *bno, mapi = 0; b < *bno + count; ) {
|
for (b = *bno, mapi = 0; b < *bno + count; ) {
|
||||||
nmap = MIN(XFS_BMAP_MAX_NMAP, count);
|
nmap = min(XFS_BMAP_MAX_NMAP, count);
|
||||||
c = (int)(*bno + count - b);
|
c = (int)(*bno + count - b);
|
||||||
error = xfs_bmapi_write(tp, dp, b, c,
|
error = xfs_bmapi_write(tp, dp, b, c,
|
||||||
xfs_bmapi_aflag(w)|XFS_BMAPI_METADATA,
|
xfs_bmapi_aflag(w)|XFS_BMAPI_METADATA,
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_DA_BTREE_H__
|
#ifndef __XFS_DA_BTREE_H__
|
||||||
#define __XFS_DA_BTREE_H__
|
#define __XFS_DA_BTREE_H__
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2002,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_DA_FORMAT_H__
|
#ifndef __XFS_DA_FORMAT_H__
|
||||||
#define __XFS_DA_FORMAT_H__
|
#define __XFS_DA_FORMAT_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_DEFER_H__
|
#ifndef __XFS_DEFER_H__
|
||||||
#define __XFS_DEFER_H__
|
#define __XFS_DEFER_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_DIR2_H__
|
#ifndef __XFS_DIR2_H__
|
||||||
#define __XFS_DIR2_H__
|
#define __XFS_DIR2_H__
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -514,8 +502,8 @@ xfs_dir2_block_addname(
|
||||||
if (mid - lowstale)
|
if (mid - lowstale)
|
||||||
memmove(&blp[lowstale], &blp[lowstale + 1],
|
memmove(&blp[lowstale], &blp[lowstale + 1],
|
||||||
(mid - lowstale) * sizeof(*blp));
|
(mid - lowstale) * sizeof(*blp));
|
||||||
lfloglow = MIN(lowstale, lfloglow);
|
lfloglow = min(lowstale, lfloglow);
|
||||||
lfloghigh = MAX(mid, lfloghigh);
|
lfloghigh = max(mid, lfloghigh);
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
* Move entries toward the high-numbered stale entry.
|
* Move entries toward the high-numbered stale entry.
|
||||||
|
@ -526,8 +514,8 @@ xfs_dir2_block_addname(
|
||||||
if (highstale - mid)
|
if (highstale - mid)
|
||||||
memmove(&blp[mid + 1], &blp[mid],
|
memmove(&blp[mid + 1], &blp[mid],
|
||||||
(highstale - mid) * sizeof(*blp));
|
(highstale - mid) * sizeof(*blp));
|
||||||
lfloglow = MIN(mid, lfloglow);
|
lfloglow = min(mid, lfloglow);
|
||||||
lfloghigh = MAX(highstale, lfloghigh);
|
lfloghigh = max(highstale, lfloghigh);
|
||||||
}
|
}
|
||||||
be32_add_cpu(&btp->stale, -1);
|
be32_add_cpu(&btp->stale, -1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -33,6 +21,11 @@
|
||||||
#include "xfs_cksum.h"
|
#include "xfs_cksum.h"
|
||||||
#include "xfs_log.h"
|
#include "xfs_log.h"
|
||||||
|
|
||||||
|
static xfs_failaddr_t xfs_dir2_data_freefind_verify(
|
||||||
|
struct xfs_dir2_data_hdr *hdr, struct xfs_dir2_data_free *bf,
|
||||||
|
struct xfs_dir2_data_unused *dup,
|
||||||
|
struct xfs_dir2_data_free **bf_ent);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check the consistency of the data block.
|
* Check the consistency of the data block.
|
||||||
* The input can also be a block-format directory.
|
* The input can also be a block-format directory.
|
||||||
|
@ -147,6 +140,8 @@ __xfs_dir3_data_check(
|
||||||
* doesn't need to be there.
|
* doesn't need to be there.
|
||||||
*/
|
*/
|
||||||
if (be16_to_cpu(dup->freetag) == XFS_DIR2_DATA_FREE_TAG) {
|
if (be16_to_cpu(dup->freetag) == XFS_DIR2_DATA_FREE_TAG) {
|
||||||
|
xfs_failaddr_t fa;
|
||||||
|
|
||||||
if (lastfree != 0)
|
if (lastfree != 0)
|
||||||
return __this_address;
|
return __this_address;
|
||||||
if (endp < p + be16_to_cpu(dup->length))
|
if (endp < p + be16_to_cpu(dup->length))
|
||||||
|
@ -154,7 +149,9 @@ __xfs_dir3_data_check(
|
||||||
if (be16_to_cpu(*xfs_dir2_data_unused_tag_p(dup)) !=
|
if (be16_to_cpu(*xfs_dir2_data_unused_tag_p(dup)) !=
|
||||||
(char *)dup - (char *)hdr)
|
(char *)dup - (char *)hdr)
|
||||||
return __this_address;
|
return __this_address;
|
||||||
dfp = xfs_dir2_data_freefind(hdr, bf, dup);
|
fa = xfs_dir2_data_freefind_verify(hdr, bf, dup, &dfp);
|
||||||
|
if (fa)
|
||||||
|
return fa;
|
||||||
if (dfp) {
|
if (dfp) {
|
||||||
i = (int)(dfp - bf);
|
i = (int)(dfp - bf);
|
||||||
if ((freeseen & (1 << i)) != 0)
|
if ((freeseen & (1 << i)) != 0)
|
||||||
|
@ -242,7 +239,8 @@ xfs_dir3_data_check(
|
||||||
if (!fa)
|
if (!fa)
|
||||||
return;
|
return;
|
||||||
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, dp->i_mount,
|
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, dp->i_mount,
|
||||||
bp->b_addr, __FILE__, __LINE__, fa);
|
bp->b_addr, BBTOB(bp->b_length), __FILE__, __LINE__,
|
||||||
|
fa);
|
||||||
ASSERT(0);
|
ASSERT(0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -380,6 +378,65 @@ xfs_dir3_data_readahead(
|
||||||
XFS_DATA_FORK, &xfs_dir3_data_reada_buf_ops);
|
XFS_DATA_FORK, &xfs_dir3_data_reada_buf_ops);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Find the bestfree entry that exactly coincides with unused directory space
|
||||||
|
* or a verifier error because the bestfree data are bad.
|
||||||
|
*/
|
||||||
|
static xfs_failaddr_t
|
||||||
|
xfs_dir2_data_freefind_verify(
|
||||||
|
struct xfs_dir2_data_hdr *hdr,
|
||||||
|
struct xfs_dir2_data_free *bf,
|
||||||
|
struct xfs_dir2_data_unused *dup,
|
||||||
|
struct xfs_dir2_data_free **bf_ent)
|
||||||
|
{
|
||||||
|
struct xfs_dir2_data_free *dfp;
|
||||||
|
xfs_dir2_data_aoff_t off;
|
||||||
|
bool matched = false;
|
||||||
|
bool seenzero = false;
|
||||||
|
|
||||||
|
*bf_ent = NULL;
|
||||||
|
off = (xfs_dir2_data_aoff_t)((char *)dup - (char *)hdr);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Validate some consistency in the bestfree table.
|
||||||
|
* Check order, non-overlapping entries, and if we find the
|
||||||
|
* one we're looking for it has to be exact.
|
||||||
|
*/
|
||||||
|
for (dfp = &bf[0]; dfp < &bf[XFS_DIR2_DATA_FD_COUNT]; dfp++) {
|
||||||
|
if (!dfp->offset) {
|
||||||
|
if (dfp->length)
|
||||||
|
return __this_address;
|
||||||
|
seenzero = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (seenzero)
|
||||||
|
return __this_address;
|
||||||
|
if (be16_to_cpu(dfp->offset) == off) {
|
||||||
|
matched = true;
|
||||||
|
if (dfp->length != dup->length)
|
||||||
|
return __this_address;
|
||||||
|
} else if (be16_to_cpu(dfp->offset) > off) {
|
||||||
|
if (off + be16_to_cpu(dup->length) >
|
||||||
|
be16_to_cpu(dfp->offset))
|
||||||
|
return __this_address;
|
||||||
|
} else {
|
||||||
|
if (be16_to_cpu(dfp->offset) +
|
||||||
|
be16_to_cpu(dfp->length) > off)
|
||||||
|
return __this_address;
|
||||||
|
}
|
||||||
|
if (!matched &&
|
||||||
|
be16_to_cpu(dfp->length) < be16_to_cpu(dup->length))
|
||||||
|
return __this_address;
|
||||||
|
if (dfp > &bf[0] &&
|
||||||
|
be16_to_cpu(dfp[-1].length) < be16_to_cpu(dfp[0].length))
|
||||||
|
return __this_address;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Looks ok so far; now try to match up with a bestfree entry. */
|
||||||
|
*bf_ent = xfs_dir2_data_freefind(hdr, bf, dup);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Given a data block and an unused entry from that block,
|
* Given a data block and an unused entry from that block,
|
||||||
* return the bestfree entry if any that corresponds to it.
|
* return the bestfree entry if any that corresponds to it.
|
||||||
|
@ -392,44 +449,9 @@ xfs_dir2_data_freefind(
|
||||||
{
|
{
|
||||||
xfs_dir2_data_free_t *dfp; /* bestfree entry */
|
xfs_dir2_data_free_t *dfp; /* bestfree entry */
|
||||||
xfs_dir2_data_aoff_t off; /* offset value needed */
|
xfs_dir2_data_aoff_t off; /* offset value needed */
|
||||||
#ifdef DEBUG
|
|
||||||
int matched; /* matched the value */
|
|
||||||
int seenzero; /* saw a 0 bestfree entry */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
off = (xfs_dir2_data_aoff_t)((char *)dup - (char *)hdr);
|
off = (xfs_dir2_data_aoff_t)((char *)dup - (char *)hdr);
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
/*
|
|
||||||
* Validate some consistency in the bestfree table.
|
|
||||||
* Check order, non-overlapping entries, and if we find the
|
|
||||||
* one we're looking for it has to be exact.
|
|
||||||
*/
|
|
||||||
ASSERT(hdr->magic == cpu_to_be32(XFS_DIR2_DATA_MAGIC) ||
|
|
||||||
hdr->magic == cpu_to_be32(XFS_DIR3_DATA_MAGIC) ||
|
|
||||||
hdr->magic == cpu_to_be32(XFS_DIR2_BLOCK_MAGIC) ||
|
|
||||||
hdr->magic == cpu_to_be32(XFS_DIR3_BLOCK_MAGIC));
|
|
||||||
for (dfp = &bf[0], seenzero = matched = 0;
|
|
||||||
dfp < &bf[XFS_DIR2_DATA_FD_COUNT];
|
|
||||||
dfp++) {
|
|
||||||
if (!dfp->offset) {
|
|
||||||
ASSERT(!dfp->length);
|
|
||||||
seenzero = 1;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
ASSERT(seenzero == 0);
|
|
||||||
if (be16_to_cpu(dfp->offset) == off) {
|
|
||||||
matched = 1;
|
|
||||||
ASSERT(dfp->length == dup->length);
|
|
||||||
} else if (off < be16_to_cpu(dfp->offset))
|
|
||||||
ASSERT(off + be16_to_cpu(dup->length) <= be16_to_cpu(dfp->offset));
|
|
||||||
else
|
|
||||||
ASSERT(be16_to_cpu(dfp->offset) + be16_to_cpu(dfp->length) <= off);
|
|
||||||
ASSERT(matched || be16_to_cpu(dfp->length) >= be16_to_cpu(dup->length));
|
|
||||||
if (dfp > &bf[0])
|
|
||||||
ASSERT(be16_to_cpu(dfp[-1].length) >= be16_to_cpu(dfp[0].length));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
/*
|
/*
|
||||||
* If this is smaller than the smallest bestfree entry,
|
* If this is smaller than the smallest bestfree entry,
|
||||||
* it can't be there since they're sorted.
|
* it can't be there since they're sorted.
|
||||||
|
@ -1124,7 +1146,7 @@ xfs_dir2_data_use_free(
|
||||||
return 0;
|
return 0;
|
||||||
corrupt:
|
corrupt:
|
||||||
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, args->dp->i_mount,
|
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, args->dp->i_mount,
|
||||||
hdr, __FILE__, __LINE__, fa);
|
hdr, sizeof(*hdr), __FILE__, __LINE__, fa);
|
||||||
return -EFSCORRUPTED;
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -81,7 +69,8 @@ xfs_dir3_leaf_check(
|
||||||
if (!fa)
|
if (!fa)
|
||||||
return;
|
return;
|
||||||
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, dp->i_mount,
|
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, dp->i_mount,
|
||||||
bp->b_addr, __FILE__, __LINE__, fa);
|
bp->b_addr, BBTOB(bp->b_length), __FILE__, __LINE__,
|
||||||
|
fa);
|
||||||
ASSERT(0);
|
ASSERT(0);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
@ -601,8 +590,8 @@ xfs_dir3_leaf_find_entry(
|
||||||
(index - lowstale - 1) *
|
(index - lowstale - 1) *
|
||||||
sizeof(xfs_dir2_leaf_entry_t));
|
sizeof(xfs_dir2_leaf_entry_t));
|
||||||
}
|
}
|
||||||
*lfloglow = MIN(lowstale, *lfloglow);
|
*lfloglow = min(lowstale, *lfloglow);
|
||||||
*lfloghigh = MAX(index - 1, *lfloghigh);
|
*lfloghigh = max(index - 1, *lfloghigh);
|
||||||
leafhdr->stale--;
|
leafhdr->stale--;
|
||||||
return &ents[index - 1];
|
return &ents[index - 1];
|
||||||
}
|
}
|
||||||
|
@ -621,8 +610,8 @@ xfs_dir3_leaf_find_entry(
|
||||||
memmove(&ents[index + 1], &ents[index],
|
memmove(&ents[index + 1], &ents[index],
|
||||||
(highstale - index) * sizeof(xfs_dir2_leaf_entry_t));
|
(highstale - index) * sizeof(xfs_dir2_leaf_entry_t));
|
||||||
}
|
}
|
||||||
*lfloglow = MIN(index, *lfloglow);
|
*lfloglow = min(index, *lfloglow);
|
||||||
*lfloghigh = MAX(highstale, *lfloghigh);
|
*lfloghigh = max(highstale, *lfloghigh);
|
||||||
leafhdr->stale--;
|
leafhdr->stale--;
|
||||||
return &ents[index];
|
return &ents[index];
|
||||||
}
|
}
|
||||||
|
@ -872,7 +861,6 @@ xfs_dir2_leaf_addname(
|
||||||
*/
|
*/
|
||||||
dup = (xfs_dir2_data_unused_t *)
|
dup = (xfs_dir2_data_unused_t *)
|
||||||
((char *)hdr + be16_to_cpu(bf[0].offset));
|
((char *)hdr + be16_to_cpu(bf[0].offset));
|
||||||
ASSERT(be16_to_cpu(dup->length) >= length);
|
|
||||||
needscan = needlog = 0;
|
needscan = needlog = 0;
|
||||||
/*
|
/*
|
||||||
* Mark the initial part of our freespace in use for the new entry.
|
* Mark the initial part of our freespace in use for the new entry.
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -84,7 +72,8 @@ xfs_dir3_leaf_check(
|
||||||
if (!fa)
|
if (!fa)
|
||||||
return;
|
return;
|
||||||
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, dp->i_mount,
|
xfs_corruption_error(__func__, XFS_ERRLEVEL_LOW, dp->i_mount,
|
||||||
bp->b_addr, __FILE__, __LINE__, fa);
|
bp->b_addr, BBTOB(bp->b_length), __FILE__, __LINE__,
|
||||||
|
fa);
|
||||||
ASSERT(0);
|
ASSERT(0);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_DIR2_PRIV_H__
|
#ifndef __XFS_DIR2_PRIV_H__
|
||||||
#define __XFS_DIR2_PRIV_H__
|
#define __XFS_DIR2_PRIV_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (C) 2017 Oracle.
|
* Copyright (C) 2017 Oracle.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_ERRORTAG_H_
|
#ifndef __XFS_ERRORTAG_H_
|
||||||
#define __XFS_ERRORTAG_H_
|
#define __XFS_ERRORTAG_H_
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_FORMAT_H__
|
#ifndef __XFS_FORMAT_H__
|
||||||
#define __XFS_FORMAT_H__
|
#define __XFS_FORMAT_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: LGPL-2.1
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1995-2005 Silicon Graphics, Inc.
|
* Copyright (c) 1995-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public License
|
|
||||||
* as published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_FS_H__
|
#ifndef __XFS_FS_H__
|
||||||
#define __XFS_FS_H__
|
#define __XFS_FS_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -133,16 +121,45 @@ xfs_inobt_get_rec(
|
||||||
struct xfs_inobt_rec_incore *irec,
|
struct xfs_inobt_rec_incore *irec,
|
||||||
int *stat)
|
int *stat)
|
||||||
{
|
{
|
||||||
|
struct xfs_mount *mp = cur->bc_mp;
|
||||||
|
xfs_agnumber_t agno = cur->bc_private.a.agno;
|
||||||
union xfs_btree_rec *rec;
|
union xfs_btree_rec *rec;
|
||||||
int error;
|
int error;
|
||||||
|
uint64_t realfree;
|
||||||
|
|
||||||
error = xfs_btree_get_rec(cur, &rec, stat);
|
error = xfs_btree_get_rec(cur, &rec, stat);
|
||||||
if (error || *stat == 0)
|
if (error || *stat == 0)
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
xfs_inobt_btrec_to_irec(cur->bc_mp, rec, irec);
|
xfs_inobt_btrec_to_irec(mp, rec, irec);
|
||||||
|
|
||||||
|
if (!xfs_verify_agino(mp, agno, irec->ir_startino))
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (irec->ir_count < XFS_INODES_PER_HOLEMASK_BIT ||
|
||||||
|
irec->ir_count > XFS_INODES_PER_CHUNK)
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (irec->ir_freecount > XFS_INODES_PER_CHUNK)
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
|
/* if there are no holes, return the first available offset */
|
||||||
|
if (!xfs_inobt_issparse(irec->ir_holemask))
|
||||||
|
realfree = irec->ir_free;
|
||||||
|
else
|
||||||
|
realfree = irec->ir_free & xfs_inobt_irec_to_allocmask(irec);
|
||||||
|
if (hweight64(realfree) != irec->ir_freecount)
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
out_bad_rec:
|
||||||
|
xfs_warn(mp,
|
||||||
|
"%s Inode BTree record corruption in AG %d detected!",
|
||||||
|
cur->bc_btnum == XFS_BTNUM_INO ? "Used" : "Free", agno);
|
||||||
|
xfs_warn(mp,
|
||||||
|
"start inode 0x%x, count 0x%x, free 0x%x freemask 0x%llx, holemask 0x%x",
|
||||||
|
irec->ir_startino, irec->ir_count, irec->ir_freecount,
|
||||||
|
irec->ir_free, irec->ir_holemask);
|
||||||
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -880,6 +897,7 @@ sparse_alloc:
|
||||||
be32_add_cpu(&agi->agi_freecount, newlen);
|
be32_add_cpu(&agi->agi_freecount, newlen);
|
||||||
pag = xfs_perag_get(args.mp, agno);
|
pag = xfs_perag_get(args.mp, agno);
|
||||||
pag->pagi_freecount += newlen;
|
pag->pagi_freecount += newlen;
|
||||||
|
pag->pagi_count += newlen;
|
||||||
xfs_perag_put(pag);
|
xfs_perag_put(pag);
|
||||||
agi->agi_newino = cpu_to_be32(newino);
|
agi->agi_newino = cpu_to_be32(newino);
|
||||||
|
|
||||||
|
@ -1974,6 +1992,7 @@ xfs_difree_inobt(
|
||||||
xfs_ialloc_log_agi(tp, agbp, XFS_AGI_COUNT | XFS_AGI_FREECOUNT);
|
xfs_ialloc_log_agi(tp, agbp, XFS_AGI_COUNT | XFS_AGI_FREECOUNT);
|
||||||
pag = xfs_perag_get(mp, agno);
|
pag = xfs_perag_get(mp, agno);
|
||||||
pag->pagi_freecount -= ilen - 1;
|
pag->pagi_freecount -= ilen - 1;
|
||||||
|
pag->pagi_count -= ilen;
|
||||||
xfs_perag_put(pag);
|
xfs_perag_put(pag);
|
||||||
xfs_trans_mod_sb(tp, XFS_TRANS_SB_ICOUNT, -ilen);
|
xfs_trans_mod_sb(tp, XFS_TRANS_SB_ICOUNT, -ilen);
|
||||||
xfs_trans_mod_sb(tp, XFS_TRANS_SB_IFREE, -(ilen - 1));
|
xfs_trans_mod_sb(tp, XFS_TRANS_SB_IFREE, -(ilen - 1));
|
||||||
|
@ -2477,26 +2496,13 @@ xfs_ialloc_log_agi(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
STATIC void
|
|
||||||
xfs_check_agi_unlinked(
|
|
||||||
struct xfs_agi *agi)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < XFS_AGI_UNLINKED_BUCKETS; i++)
|
|
||||||
ASSERT(agi->agi_unlinked[i]);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#define xfs_check_agi_unlinked(agi)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static xfs_failaddr_t
|
static xfs_failaddr_t
|
||||||
xfs_agi_verify(
|
xfs_agi_verify(
|
||||||
struct xfs_buf *bp)
|
struct xfs_buf *bp)
|
||||||
{
|
{
|
||||||
struct xfs_mount *mp = bp->b_target->bt_mount;
|
struct xfs_mount *mp = bp->b_target->bt_mount;
|
||||||
struct xfs_agi *agi = XFS_BUF_TO_AGI(bp);
|
struct xfs_agi *agi = XFS_BUF_TO_AGI(bp);
|
||||||
|
int i;
|
||||||
|
|
||||||
if (xfs_sb_version_hascrc(&mp->m_sb)) {
|
if (xfs_sb_version_hascrc(&mp->m_sb)) {
|
||||||
if (!uuid_equal(&agi->agi_uuid, &mp->m_sb.sb_meta_uuid))
|
if (!uuid_equal(&agi->agi_uuid, &mp->m_sb.sb_meta_uuid))
|
||||||
|
@ -2532,7 +2538,13 @@ xfs_agi_verify(
|
||||||
if (bp->b_pag && be32_to_cpu(agi->agi_seqno) != bp->b_pag->pag_agno)
|
if (bp->b_pag && be32_to_cpu(agi->agi_seqno) != bp->b_pag->pag_agno)
|
||||||
return __this_address;
|
return __this_address;
|
||||||
|
|
||||||
xfs_check_agi_unlinked(agi);
|
for (i = 0; i < XFS_AGI_UNLINKED_BUCKETS; i++) {
|
||||||
|
if (agi->agi_unlinked[i] == NULLAGINO)
|
||||||
|
continue;
|
||||||
|
if (!xfs_verify_ino(mp, be32_to_cpu(agi->agi_unlinked[i])))
|
||||||
|
return __this_address;
|
||||||
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2664,96 +2676,6 @@ xfs_ialloc_pagi_init(
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Calculate the first and last possible inode number in an AG. */
|
|
||||||
void
|
|
||||||
xfs_ialloc_agino_range(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_agnumber_t agno,
|
|
||||||
xfs_agino_t *first,
|
|
||||||
xfs_agino_t *last)
|
|
||||||
{
|
|
||||||
xfs_agblock_t bno;
|
|
||||||
xfs_agblock_t eoag;
|
|
||||||
|
|
||||||
eoag = xfs_ag_block_count(mp, agno);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Calculate the first inode, which will be in the first
|
|
||||||
* cluster-aligned block after the AGFL.
|
|
||||||
*/
|
|
||||||
bno = round_up(XFS_AGFL_BLOCK(mp) + 1,
|
|
||||||
xfs_ialloc_cluster_alignment(mp));
|
|
||||||
*first = XFS_OFFBNO_TO_AGINO(mp, bno, 0);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Calculate the last inode, which will be at the end of the
|
|
||||||
* last (aligned) cluster that can be allocated in the AG.
|
|
||||||
*/
|
|
||||||
bno = round_down(eoag, xfs_ialloc_cluster_alignment(mp));
|
|
||||||
*last = XFS_OFFBNO_TO_AGINO(mp, bno, 0) - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Verify that an AG inode number pointer neither points outside the AG
|
|
||||||
* nor points at static metadata.
|
|
||||||
*/
|
|
||||||
bool
|
|
||||||
xfs_verify_agino(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_agnumber_t agno,
|
|
||||||
xfs_agino_t agino)
|
|
||||||
{
|
|
||||||
xfs_agino_t first;
|
|
||||||
xfs_agino_t last;
|
|
||||||
|
|
||||||
xfs_ialloc_agino_range(mp, agno, &first, &last);
|
|
||||||
return agino >= first && agino <= last;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Verify that an FS inode number pointer neither points outside the
|
|
||||||
* filesystem nor points at static AG metadata.
|
|
||||||
*/
|
|
||||||
bool
|
|
||||||
xfs_verify_ino(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_ino_t ino)
|
|
||||||
{
|
|
||||||
xfs_agnumber_t agno = XFS_INO_TO_AGNO(mp, ino);
|
|
||||||
xfs_agino_t agino = XFS_INO_TO_AGINO(mp, ino);
|
|
||||||
|
|
||||||
if (agno >= mp->m_sb.sb_agcount)
|
|
||||||
return false;
|
|
||||||
if (XFS_AGINO_TO_INO(mp, agno, agino) != ino)
|
|
||||||
return false;
|
|
||||||
return xfs_verify_agino(mp, agno, agino);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Is this an internal inode number? */
|
|
||||||
bool
|
|
||||||
xfs_internal_inum(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_ino_t ino)
|
|
||||||
{
|
|
||||||
return ino == mp->m_sb.sb_rbmino || ino == mp->m_sb.sb_rsumino ||
|
|
||||||
(xfs_sb_version_hasquota(&mp->m_sb) &&
|
|
||||||
xfs_is_quota_inode(&mp->m_sb, ino));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Verify that a directory entry's inode number doesn't point at an internal
|
|
||||||
* inode, empty space, or static AG metadata.
|
|
||||||
*/
|
|
||||||
bool
|
|
||||||
xfs_verify_dir_ino(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_ino_t ino)
|
|
||||||
{
|
|
||||||
if (xfs_internal_inum(mp, ino))
|
|
||||||
return false;
|
|
||||||
return xfs_verify_ino(mp, ino);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Is there an inode record covering a given range of inode numbers? */
|
/* Is there an inode record covering a given range of inode numbers? */
|
||||||
int
|
int
|
||||||
xfs_ialloc_has_inode_record(
|
xfs_ialloc_has_inode_record(
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_IALLOC_H__
|
#ifndef __XFS_IALLOC_H__
|
||||||
#define __XFS_IALLOC_H__
|
#define __XFS_IALLOC_H__
|
||||||
|
@ -181,12 +169,5 @@ int xfs_inobt_insert_rec(struct xfs_btree_cur *cur, uint16_t holemask,
|
||||||
int *stat);
|
int *stat);
|
||||||
|
|
||||||
int xfs_ialloc_cluster_alignment(struct xfs_mount *mp);
|
int xfs_ialloc_cluster_alignment(struct xfs_mount *mp);
|
||||||
void xfs_ialloc_agino_range(struct xfs_mount *mp, xfs_agnumber_t agno,
|
|
||||||
xfs_agino_t *first, xfs_agino_t *last);
|
|
||||||
bool xfs_verify_agino(struct xfs_mount *mp, xfs_agnumber_t agno,
|
|
||||||
xfs_agino_t agino);
|
|
||||||
bool xfs_verify_ino(struct xfs_mount *mp, xfs_ino_t ino);
|
|
||||||
bool xfs_internal_inum(struct xfs_mount *mp, xfs_ino_t ino);
|
|
||||||
bool xfs_verify_dir_ino(struct xfs_mount *mp, xfs_ino_t ino);
|
|
||||||
|
|
||||||
#endif /* __XFS_IALLOC_H__ */
|
#endif /* __XFS_IALLOC_H__ */
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_IALLOC_BTREE_H__
|
#ifndef __XFS_IALLOC_BTREE_H__
|
||||||
#define __XFS_IALLOC_BTREE_H__
|
#define __XFS_IALLOC_BTREE_H__
|
||||||
|
|
|
@ -1,14 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2017 Christoph Hellwig.
|
* Copyright (c) 2017 Christoph Hellwig.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms and conditions of the GNU General Public License,
|
|
||||||
* version 2, as published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
||||||
* more details.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/cache.h>
|
#include <linux/cache.h>
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -201,11 +189,6 @@ xfs_imap_to_bp(
|
||||||
ASSERT(buf_flags & XBF_TRYLOCK);
|
ASSERT(buf_flags & XBF_TRYLOCK);
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (error == -EFSCORRUPTED &&
|
|
||||||
(iget_flags & XFS_IGET_UNTRUSTED))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
xfs_warn(mp, "%s: xfs_trans_read_buf() returned error %d.",
|
xfs_warn(mp, "%s: xfs_trans_read_buf() returned error %d.",
|
||||||
__func__, error);
|
__func__, error);
|
||||||
return error;
|
return error;
|
||||||
|
@ -397,6 +380,7 @@ xfs_dinode_verify(
|
||||||
xfs_ino_t ino,
|
xfs_ino_t ino,
|
||||||
struct xfs_dinode *dip)
|
struct xfs_dinode *dip)
|
||||||
{
|
{
|
||||||
|
xfs_failaddr_t fa;
|
||||||
uint16_t mode;
|
uint16_t mode;
|
||||||
uint16_t flags;
|
uint16_t flags;
|
||||||
uint64_t flags2;
|
uint64_t flags2;
|
||||||
|
@ -513,6 +497,12 @@ xfs_dinode_verify(
|
||||||
return __this_address;
|
return __this_address;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* extent size hint validation */
|
||||||
|
fa = xfs_inode_validate_extsize(mp, be32_to_cpu(dip->di_extsize),
|
||||||
|
mode, flags);
|
||||||
|
if (fa)
|
||||||
|
return fa;
|
||||||
|
|
||||||
/* only version 3 or greater inodes are extensively verified here */
|
/* only version 3 or greater inodes are extensively verified here */
|
||||||
if (dip->di_version < 3)
|
if (dip->di_version < 3)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -536,6 +526,12 @@ xfs_dinode_verify(
|
||||||
if ((flags2 & XFS_DIFLAG2_REFLINK) && (flags2 & XFS_DIFLAG2_DAX))
|
if ((flags2 & XFS_DIFLAG2_REFLINK) && (flags2 & XFS_DIFLAG2_DAX))
|
||||||
return __this_address;
|
return __this_address;
|
||||||
|
|
||||||
|
/* COW extent size hint validation */
|
||||||
|
fa = xfs_inode_validate_cowextsize(mp, be32_to_cpu(dip->di_cowextsize),
|
||||||
|
mode, flags, flags2);
|
||||||
|
if (fa)
|
||||||
|
return fa;
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_INODE_BUF_H__
|
#ifndef __XFS_INODE_BUF_H__
|
||||||
#define __XFS_INODE_BUF_H__
|
#define __XFS_INODE_BUF_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include <linux/log2.h>
|
#include <linux/log2.h>
|
||||||
|
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_INODE_FORK_H__
|
#ifndef __XFS_INODE_FORK_H__
|
||||||
#define __XFS_INODE_FORK_H__
|
#define __XFS_INODE_FORK_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_LOG_FORMAT_H__
|
#ifndef __XFS_LOG_FORMAT_H__
|
||||||
#define __XFS_LOG_FORMAT_H__
|
#define __XFS_LOG_FORMAT_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_LOG_RECOVER_H__
|
#ifndef __XFS_LOG_RECOVER_H__
|
||||||
#define __XFS_LOG_RECOVER_H__
|
#define __XFS_LOG_RECOVER_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2013 Jie Liu.
|
* Copyright (c) 2013 Jie Liu.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_QUOTA_DEFS_H__
|
#ifndef __XFS_QUOTA_DEFS_H__
|
||||||
#define __XFS_QUOTA_DEFS_H__
|
#define __XFS_QUOTA_DEFS_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -125,16 +111,53 @@ xfs_refcount_get_rec(
|
||||||
struct xfs_refcount_irec *irec,
|
struct xfs_refcount_irec *irec,
|
||||||
int *stat)
|
int *stat)
|
||||||
{
|
{
|
||||||
|
struct xfs_mount *mp = cur->bc_mp;
|
||||||
|
xfs_agnumber_t agno = cur->bc_private.a.agno;
|
||||||
union xfs_btree_rec *rec;
|
union xfs_btree_rec *rec;
|
||||||
int error;
|
int error;
|
||||||
|
xfs_agblock_t realstart;
|
||||||
|
|
||||||
error = xfs_btree_get_rec(cur, &rec, stat);
|
error = xfs_btree_get_rec(cur, &rec, stat);
|
||||||
if (!error && *stat == 1) {
|
if (error || !*stat)
|
||||||
xfs_refcount_btrec_to_irec(rec, irec);
|
|
||||||
trace_xfs_refcount_get(cur->bc_mp, cur->bc_private.a.agno,
|
|
||||||
irec);
|
|
||||||
}
|
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
|
xfs_refcount_btrec_to_irec(rec, irec);
|
||||||
|
|
||||||
|
agno = cur->bc_private.a.agno;
|
||||||
|
if (irec->rc_blockcount == 0 || irec->rc_blockcount > MAXREFCEXTLEN)
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
|
/* handle special COW-staging state */
|
||||||
|
realstart = irec->rc_startblock;
|
||||||
|
if (realstart & XFS_REFC_COW_START) {
|
||||||
|
if (irec->rc_refcount != 1)
|
||||||
|
goto out_bad_rec;
|
||||||
|
realstart &= ~XFS_REFC_COW_START;
|
||||||
|
} else if (irec->rc_refcount < 2) {
|
||||||
|
goto out_bad_rec;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* check for valid extent range, including overflow */
|
||||||
|
if (!xfs_verify_agbno(mp, agno, realstart))
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (realstart > realstart + irec->rc_blockcount)
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (!xfs_verify_agbno(mp, agno, realstart + irec->rc_blockcount - 1))
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
|
if (irec->rc_refcount == 0 || irec->rc_refcount > MAXREFCOUNT)
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
|
trace_xfs_refcount_get(cur->bc_mp, cur->bc_private.a.agno, irec);
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
out_bad_rec:
|
||||||
|
xfs_warn(mp,
|
||||||
|
"Refcount BTree record corruption in AG %d detected!", agno);
|
||||||
|
xfs_warn(mp,
|
||||||
|
"Start block 0x%x, block count 0x%x, references 0x%x",
|
||||||
|
irec->rc_startblock, irec->rc_blockcount, irec->rc_refcount);
|
||||||
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_REFCOUNT_H__
|
#ifndef __XFS_REFCOUNT_H__
|
||||||
#define __XFS_REFCOUNT_H__
|
#define __XFS_REFCOUNT_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -192,7 +178,6 @@ xfs_refcountbt_init_ptr_from_cur(
|
||||||
struct xfs_agf *agf = XFS_BUF_TO_AGF(cur->bc_private.a.agbp);
|
struct xfs_agf *agf = XFS_BUF_TO_AGF(cur->bc_private.a.agbp);
|
||||||
|
|
||||||
ASSERT(cur->bc_private.a.agno == be32_to_cpu(agf->agf_seqno));
|
ASSERT(cur->bc_private.a.agno == be32_to_cpu(agf->agf_seqno));
|
||||||
ASSERT(agf->agf_refcount_root != 0);
|
|
||||||
|
|
||||||
ptr->s = agf->agf_refcount_root;
|
ptr->s = agf->agf_refcount_root;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_REFCOUNT_BTREE_H__
|
#ifndef __XFS_REFCOUNT_BTREE_H__
|
||||||
#define __XFS_REFCOUNT_BTREE_H__
|
#define __XFS_REFCOUNT_BTREE_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2014 Red Hat, Inc.
|
* Copyright (c) 2014 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -39,6 +27,7 @@
|
||||||
#include "xfs_extent_busy.h"
|
#include "xfs_extent_busy.h"
|
||||||
#include "xfs_bmap.h"
|
#include "xfs_bmap.h"
|
||||||
#include "xfs_inode.h"
|
#include "xfs_inode.h"
|
||||||
|
#include "xfs_ialloc.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Lookup the first record less than or equal to [bno, len, owner, offset]
|
* Lookup the first record less than or equal to [bno, len, owner, offset]
|
||||||
|
@ -203,6 +192,8 @@ xfs_rmap_get_rec(
|
||||||
struct xfs_rmap_irec *irec,
|
struct xfs_rmap_irec *irec,
|
||||||
int *stat)
|
int *stat)
|
||||||
{
|
{
|
||||||
|
struct xfs_mount *mp = cur->bc_mp;
|
||||||
|
xfs_agnumber_t agno = cur->bc_private.a.agno;
|
||||||
union xfs_btree_rec *rec;
|
union xfs_btree_rec *rec;
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
|
@ -210,7 +201,43 @@ xfs_rmap_get_rec(
|
||||||
if (error || !*stat)
|
if (error || !*stat)
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
return xfs_rmap_btrec_to_irec(rec, irec);
|
if (xfs_rmap_btrec_to_irec(rec, irec))
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
|
if (irec->rm_blockcount == 0)
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (irec->rm_startblock <= XFS_AGFL_BLOCK(mp)) {
|
||||||
|
if (irec->rm_owner != XFS_RMAP_OWN_FS)
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (irec->rm_blockcount != XFS_AGFL_BLOCK(mp) + 1)
|
||||||
|
goto out_bad_rec;
|
||||||
|
} else {
|
||||||
|
/* check for valid extent range, including overflow */
|
||||||
|
if (!xfs_verify_agbno(mp, agno, irec->rm_startblock))
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (irec->rm_startblock >
|
||||||
|
irec->rm_startblock + irec->rm_blockcount)
|
||||||
|
goto out_bad_rec;
|
||||||
|
if (!xfs_verify_agbno(mp, agno,
|
||||||
|
irec->rm_startblock + irec->rm_blockcount - 1))
|
||||||
|
goto out_bad_rec;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(xfs_verify_ino(mp, irec->rm_owner) ||
|
||||||
|
(irec->rm_owner <= XFS_RMAP_OWN_FS &&
|
||||||
|
irec->rm_owner >= XFS_RMAP_OWN_MIN)))
|
||||||
|
goto out_bad_rec;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
out_bad_rec:
|
||||||
|
xfs_warn(mp,
|
||||||
|
"Reverse Mapping BTree record corruption in AG %d detected!",
|
||||||
|
agno);
|
||||||
|
xfs_warn(mp,
|
||||||
|
"Owner 0x%llx, flags 0x%x, start block 0x%x block count 0x%x",
|
||||||
|
irec->rm_owner, irec->rm_flags, irec->rm_startblock,
|
||||||
|
irec->rm_blockcount);
|
||||||
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct xfs_find_left_neighbor_info {
|
struct xfs_find_left_neighbor_info {
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
* Copyright (C) 2016 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_RMAP_H__
|
#ifndef __XFS_RMAP_H__
|
||||||
#define __XFS_RMAP_H__
|
#define __XFS_RMAP_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2014 Red Hat, Inc.
|
* Copyright (c) 2014 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -234,7 +222,6 @@ xfs_rmapbt_init_ptr_from_cur(
|
||||||
struct xfs_agf *agf = XFS_BUF_TO_AGF(cur->bc_private.a.agbp);
|
struct xfs_agf *agf = XFS_BUF_TO_AGF(cur->bc_private.a.agbp);
|
||||||
|
|
||||||
ASSERT(cur->bc_private.a.agno == be32_to_cpu(agf->agf_seqno));
|
ASSERT(cur->bc_private.a.agno == be32_to_cpu(agf->agf_seqno));
|
||||||
ASSERT(agf->agf_roots[cur->bc_btnum] != 0);
|
|
||||||
|
|
||||||
ptr->s = agf->agf_roots[cur->bc_btnum];
|
ptr->s = agf->agf_roots[cur->bc_btnum];
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2014 Red Hat, Inc.
|
* Copyright (c) 2014 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_RMAP_BTREE_H__
|
#ifndef __XFS_RMAP_BTREE_H__
|
||||||
#define __XFS_RMAP_BTREE_H__
|
#define __XFS_RMAP_BTREE_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -1092,18 +1080,6 @@ xfs_rtalloc_query_all(
|
||||||
return xfs_rtalloc_query_range(tp, &keys[0], &keys[1], fn, priv);
|
return xfs_rtalloc_query_range(tp, &keys[0], &keys[1], fn, priv);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Verify that an realtime block number pointer doesn't point off the
|
|
||||||
* end of the realtime device.
|
|
||||||
*/
|
|
||||||
bool
|
|
||||||
xfs_verify_rtbno(
|
|
||||||
struct xfs_mount *mp,
|
|
||||||
xfs_rtblock_t rtbno)
|
|
||||||
{
|
|
||||||
return rtbno < mp->m_sb.sb_rblocks;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Is the given extent all free? */
|
/* Is the given extent all free? */
|
||||||
int
|
int
|
||||||
xfs_rtalloc_extent_is_free(
|
xfs_rtalloc_extent_is_free(
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -278,6 +266,22 @@ xfs_mount_validate_sb(
|
||||||
return -EFSCORRUPTED;
|
return -EFSCORRUPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (sbp->sb_unit) {
|
||||||
|
if (!xfs_sb_version_hasdalign(sbp) ||
|
||||||
|
sbp->sb_unit > sbp->sb_width ||
|
||||||
|
(sbp->sb_width % sbp->sb_unit) != 0) {
|
||||||
|
xfs_notice(mp, "SB stripe unit sanity check failed");
|
||||||
|
return -EFSCORRUPTED;
|
||||||
|
}
|
||||||
|
} else if (xfs_sb_version_hasdalign(sbp)) {
|
||||||
|
xfs_notice(mp, "SB stripe alignment sanity check failed");
|
||||||
|
return -EFSCORRUPTED;
|
||||||
|
} else if (sbp->sb_width) {
|
||||||
|
xfs_notice(mp, "SB stripe width sanity check failed");
|
||||||
|
return -EFSCORRUPTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (xfs_sb_version_hascrc(&mp->m_sb) &&
|
if (xfs_sb_version_hascrc(&mp->m_sb) &&
|
||||||
sbp->sb_blocksize < XFS_MIN_CRC_BLOCKSIZE) {
|
sbp->sb_blocksize < XFS_MIN_CRC_BLOCKSIZE) {
|
||||||
xfs_notice(mp, "v5 SB sanity check failed");
|
xfs_notice(mp, "v5 SB sanity check failed");
|
||||||
|
@ -767,7 +771,7 @@ xfs_sb_mount_common(
|
||||||
mp->m_refc_mnr[1] = mp->m_refc_mxr[1] / 2;
|
mp->m_refc_mnr[1] = mp->m_refc_mxr[1] / 2;
|
||||||
|
|
||||||
mp->m_bsize = XFS_FSB_TO_BB(mp, 1);
|
mp->m_bsize = XFS_FSB_TO_BB(mp, 1);
|
||||||
mp->m_ialloc_inos = (int)MAX((uint16_t)XFS_INODES_PER_CHUNK,
|
mp->m_ialloc_inos = max_t(uint16_t, XFS_INODES_PER_CHUNK,
|
||||||
sbp->sb_inopblock);
|
sbp->sb_inopblock);
|
||||||
mp->m_ialloc_blks = mp->m_ialloc_inos >> sbp->sb_inopblog;
|
mp->m_ialloc_blks = mp->m_ialloc_inos >> sbp->sb_inopblog;
|
||||||
|
|
||||||
|
@ -970,14 +974,16 @@ xfs_sync_sb_buf(
|
||||||
struct xfs_mount *mp)
|
struct xfs_mount *mp)
|
||||||
{
|
{
|
||||||
struct xfs_trans *tp;
|
struct xfs_trans *tp;
|
||||||
|
struct xfs_buf *bp;
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
error = xfs_trans_alloc(mp, &M_RES(mp)->tr_sb, 0, 0, 0, &tp);
|
error = xfs_trans_alloc(mp, &M_RES(mp)->tr_sb, 0, 0, 0, &tp);
|
||||||
if (error)
|
if (error)
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
|
bp = xfs_trans_getsb(tp, mp, 0);
|
||||||
xfs_log_sb(tp);
|
xfs_log_sb(tp);
|
||||||
xfs_trans_bhold(tp, mp->m_sb_bp);
|
xfs_trans_bhold(tp, bp);
|
||||||
xfs_trans_set_sync(tp);
|
xfs_trans_set_sync(tp);
|
||||||
error = xfs_trans_commit(tp);
|
error = xfs_trans_commit(tp);
|
||||||
if (error)
|
if (error)
|
||||||
|
@ -985,9 +991,9 @@ xfs_sync_sb_buf(
|
||||||
/*
|
/*
|
||||||
* write out the sb buffer to get the changes to disk
|
* write out the sb buffer to get the changes to disk
|
||||||
*/
|
*/
|
||||||
error = xfs_bwrite(mp->m_sb_bp);
|
error = xfs_bwrite(bp);
|
||||||
out:
|
out:
|
||||||
xfs_buf_relse(mp->m_sb_bp);
|
xfs_buf_relse(bp);
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SB_H__
|
#ifndef __XFS_SB_H__
|
||||||
#define __XFS_SB_H__
|
#define __XFS_SB_H__
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2013 Red Hat, Inc.
|
* Copyright (c) 2013 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SHARED_H__
|
#ifndef __XFS_SHARED_H__
|
||||||
#define __XFS_SHARED_H__
|
#define __XFS_SHARED_H__
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
||||||
* Copyright (c) 2012-2013 Red Hat, Inc.
|
* Copyright (c) 2012-2013 Red Hat, Inc.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,20 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
|
||||||
* Copyright (C) 2010 Red Hat, Inc.
|
* Copyright (C) 2010 Red Hat, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -248,7 +236,7 @@ xfs_calc_write_reservation(
|
||||||
struct xfs_mount *mp)
|
struct xfs_mount *mp)
|
||||||
{
|
{
|
||||||
return XFS_DQUOT_LOGRES(mp) +
|
return XFS_DQUOT_LOGRES(mp) +
|
||||||
MAX((xfs_calc_inode_res(mp, 1) +
|
max((xfs_calc_inode_res(mp, 1) +
|
||||||
xfs_calc_buf_res(XFS_BM_MAXLEVELS(mp, XFS_DATA_FORK),
|
xfs_calc_buf_res(XFS_BM_MAXLEVELS(mp, XFS_DATA_FORK),
|
||||||
XFS_FSB_TO_B(mp, 1)) +
|
XFS_FSB_TO_B(mp, 1)) +
|
||||||
xfs_calc_buf_res(3, mp->m_sb.sb_sectsize) +
|
xfs_calc_buf_res(3, mp->m_sb.sb_sectsize) +
|
||||||
|
@ -275,7 +263,7 @@ xfs_calc_itruncate_reservation(
|
||||||
struct xfs_mount *mp)
|
struct xfs_mount *mp)
|
||||||
{
|
{
|
||||||
return XFS_DQUOT_LOGRES(mp) +
|
return XFS_DQUOT_LOGRES(mp) +
|
||||||
MAX((xfs_calc_inode_res(mp, 1) +
|
max((xfs_calc_inode_res(mp, 1) +
|
||||||
xfs_calc_buf_res(XFS_BM_MAXLEVELS(mp, XFS_DATA_FORK) + 1,
|
xfs_calc_buf_res(XFS_BM_MAXLEVELS(mp, XFS_DATA_FORK) + 1,
|
||||||
XFS_FSB_TO_B(mp, 1))),
|
XFS_FSB_TO_B(mp, 1))),
|
||||||
(xfs_calc_buf_res(9, mp->m_sb.sb_sectsize) +
|
(xfs_calc_buf_res(9, mp->m_sb.sb_sectsize) +
|
||||||
|
@ -300,7 +288,7 @@ xfs_calc_rename_reservation(
|
||||||
struct xfs_mount *mp)
|
struct xfs_mount *mp)
|
||||||
{
|
{
|
||||||
return XFS_DQUOT_LOGRES(mp) +
|
return XFS_DQUOT_LOGRES(mp) +
|
||||||
MAX((xfs_calc_inode_res(mp, 4) +
|
max((xfs_calc_inode_res(mp, 4) +
|
||||||
xfs_calc_buf_res(2 * XFS_DIROP_LOG_COUNT(mp),
|
xfs_calc_buf_res(2 * XFS_DIROP_LOG_COUNT(mp),
|
||||||
XFS_FSB_TO_B(mp, 1))),
|
XFS_FSB_TO_B(mp, 1))),
|
||||||
(xfs_calc_buf_res(7, mp->m_sb.sb_sectsize) +
|
(xfs_calc_buf_res(7, mp->m_sb.sb_sectsize) +
|
||||||
|
@ -340,7 +328,7 @@ xfs_calc_link_reservation(
|
||||||
{
|
{
|
||||||
return XFS_DQUOT_LOGRES(mp) +
|
return XFS_DQUOT_LOGRES(mp) +
|
||||||
xfs_calc_iunlink_remove_reservation(mp) +
|
xfs_calc_iunlink_remove_reservation(mp) +
|
||||||
MAX((xfs_calc_inode_res(mp, 2) +
|
max((xfs_calc_inode_res(mp, 2) +
|
||||||
xfs_calc_buf_res(XFS_DIROP_LOG_COUNT(mp),
|
xfs_calc_buf_res(XFS_DIROP_LOG_COUNT(mp),
|
||||||
XFS_FSB_TO_B(mp, 1))),
|
XFS_FSB_TO_B(mp, 1))),
|
||||||
(xfs_calc_buf_res(3, mp->m_sb.sb_sectsize) +
|
(xfs_calc_buf_res(3, mp->m_sb.sb_sectsize) +
|
||||||
|
@ -378,7 +366,7 @@ xfs_calc_remove_reservation(
|
||||||
{
|
{
|
||||||
return XFS_DQUOT_LOGRES(mp) +
|
return XFS_DQUOT_LOGRES(mp) +
|
||||||
xfs_calc_iunlink_add_reservation(mp) +
|
xfs_calc_iunlink_add_reservation(mp) +
|
||||||
MAX((xfs_calc_inode_res(mp, 1) +
|
max((xfs_calc_inode_res(mp, 1) +
|
||||||
xfs_calc_buf_res(XFS_DIROP_LOG_COUNT(mp),
|
xfs_calc_buf_res(XFS_DIROP_LOG_COUNT(mp),
|
||||||
XFS_FSB_TO_B(mp, 1))),
|
XFS_FSB_TO_B(mp, 1))),
|
||||||
(xfs_calc_buf_res(4, mp->m_sb.sb_sectsize) +
|
(xfs_calc_buf_res(4, mp->m_sb.sb_sectsize) +
|
||||||
|
@ -436,7 +424,7 @@ STATIC uint
|
||||||
xfs_calc_icreate_reservation(xfs_mount_t *mp)
|
xfs_calc_icreate_reservation(xfs_mount_t *mp)
|
||||||
{
|
{
|
||||||
return XFS_DQUOT_LOGRES(mp) +
|
return XFS_DQUOT_LOGRES(mp) +
|
||||||
MAX(xfs_calc_icreate_resv_alloc(mp),
|
max(xfs_calc_icreate_resv_alloc(mp),
|
||||||
xfs_calc_create_resv_modify(mp));
|
xfs_calc_create_resv_modify(mp));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -644,7 +632,7 @@ STATIC uint
|
||||||
xfs_calc_attrinval_reservation(
|
xfs_calc_attrinval_reservation(
|
||||||
struct xfs_mount *mp)
|
struct xfs_mount *mp)
|
||||||
{
|
{
|
||||||
return MAX((xfs_calc_inode_res(mp, 1) +
|
return max((xfs_calc_inode_res(mp, 1) +
|
||||||
xfs_calc_buf_res(XFS_BM_MAXLEVELS(mp, XFS_ATTR_FORK),
|
xfs_calc_buf_res(XFS_BM_MAXLEVELS(mp, XFS_ATTR_FORK),
|
||||||
XFS_FSB_TO_B(mp, 1))),
|
XFS_FSB_TO_B(mp, 1))),
|
||||||
(xfs_calc_buf_res(9, mp->m_sb.sb_sectsize) +
|
(xfs_calc_buf_res(9, mp->m_sb.sb_sectsize) +
|
||||||
|
@ -708,7 +696,7 @@ xfs_calc_attrrm_reservation(
|
||||||
struct xfs_mount *mp)
|
struct xfs_mount *mp)
|
||||||
{
|
{
|
||||||
return XFS_DQUOT_LOGRES(mp) +
|
return XFS_DQUOT_LOGRES(mp) +
|
||||||
MAX((xfs_calc_inode_res(mp, 1) +
|
max((xfs_calc_inode_res(mp, 1) +
|
||||||
xfs_calc_buf_res(XFS_DA_NODE_MAXDEPTH,
|
xfs_calc_buf_res(XFS_DA_NODE_MAXDEPTH,
|
||||||
XFS_FSB_TO_B(mp, 1)) +
|
XFS_FSB_TO_B(mp, 1)) +
|
||||||
(uint)XFS_FSB_TO_B(mp,
|
(uint)XFS_FSB_TO_B(mp,
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_TRANS_RESV_H__
|
#ifndef __XFS_TRANS_RESV_H__
|
||||||
#define __XFS_TRANS_RESV_H__
|
#define __XFS_TRANS_RESV_H__
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000,2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_TRANS_SPACE_H__
|
#ifndef __XFS_TRANS_SPACE_H__
|
||||||
#define __XFS_TRANS_SPACE_H__
|
#define __XFS_TRANS_SPACE_H__
|
||||||
|
|
|
@ -0,0 +1,173 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
|
||||||
|
* Copyright (C) 2017 Oracle.
|
||||||
|
* All Rights Reserved.
|
||||||
|
*/
|
||||||
|
#include "xfs.h"
|
||||||
|
#include "xfs_fs.h"
|
||||||
|
#include "xfs_format.h"
|
||||||
|
#include "xfs_log_format.h"
|
||||||
|
#include "xfs_shared.h"
|
||||||
|
#include "xfs_trans_resv.h"
|
||||||
|
#include "xfs_bit.h"
|
||||||
|
#include "xfs_sb.h"
|
||||||
|
#include "xfs_mount.h"
|
||||||
|
#include "xfs_defer.h"
|
||||||
|
#include "xfs_inode.h"
|
||||||
|
#include "xfs_btree.h"
|
||||||
|
#include "xfs_rmap.h"
|
||||||
|
#include "xfs_alloc_btree.h"
|
||||||
|
#include "xfs_alloc.h"
|
||||||
|
#include "xfs_ialloc.h"
|
||||||
|
|
||||||
|
/* Find the size of the AG, in blocks. */
|
||||||
|
xfs_agblock_t
|
||||||
|
xfs_ag_block_count(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_agnumber_t agno)
|
||||||
|
{
|
||||||
|
ASSERT(agno < mp->m_sb.sb_agcount);
|
||||||
|
|
||||||
|
if (agno < mp->m_sb.sb_agcount - 1)
|
||||||
|
return mp->m_sb.sb_agblocks;
|
||||||
|
return mp->m_sb.sb_dblocks - (agno * mp->m_sb.sb_agblocks);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that an AG block number pointer neither points outside the AG
|
||||||
|
* nor points at static metadata.
|
||||||
|
*/
|
||||||
|
bool
|
||||||
|
xfs_verify_agbno(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_agnumber_t agno,
|
||||||
|
xfs_agblock_t agbno)
|
||||||
|
{
|
||||||
|
xfs_agblock_t eoag;
|
||||||
|
|
||||||
|
eoag = xfs_ag_block_count(mp, agno);
|
||||||
|
if (agbno >= eoag)
|
||||||
|
return false;
|
||||||
|
if (agbno <= XFS_AGFL_BLOCK(mp))
|
||||||
|
return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that an FS block number pointer neither points outside the
|
||||||
|
* filesystem nor points at static AG metadata.
|
||||||
|
*/
|
||||||
|
bool
|
||||||
|
xfs_verify_fsbno(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_fsblock_t fsbno)
|
||||||
|
{
|
||||||
|
xfs_agnumber_t agno = XFS_FSB_TO_AGNO(mp, fsbno);
|
||||||
|
|
||||||
|
if (agno >= mp->m_sb.sb_agcount)
|
||||||
|
return false;
|
||||||
|
return xfs_verify_agbno(mp, agno, XFS_FSB_TO_AGBNO(mp, fsbno));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Calculate the first and last possible inode number in an AG. */
|
||||||
|
void
|
||||||
|
xfs_agino_range(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_agnumber_t agno,
|
||||||
|
xfs_agino_t *first,
|
||||||
|
xfs_agino_t *last)
|
||||||
|
{
|
||||||
|
xfs_agblock_t bno;
|
||||||
|
xfs_agblock_t eoag;
|
||||||
|
|
||||||
|
eoag = xfs_ag_block_count(mp, agno);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Calculate the first inode, which will be in the first
|
||||||
|
* cluster-aligned block after the AGFL.
|
||||||
|
*/
|
||||||
|
bno = round_up(XFS_AGFL_BLOCK(mp) + 1,
|
||||||
|
xfs_ialloc_cluster_alignment(mp));
|
||||||
|
*first = XFS_OFFBNO_TO_AGINO(mp, bno, 0);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Calculate the last inode, which will be at the end of the
|
||||||
|
* last (aligned) cluster that can be allocated in the AG.
|
||||||
|
*/
|
||||||
|
bno = round_down(eoag, xfs_ialloc_cluster_alignment(mp));
|
||||||
|
*last = XFS_OFFBNO_TO_AGINO(mp, bno, 0) - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that an AG inode number pointer neither points outside the AG
|
||||||
|
* nor points at static metadata.
|
||||||
|
*/
|
||||||
|
bool
|
||||||
|
xfs_verify_agino(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_agnumber_t agno,
|
||||||
|
xfs_agino_t agino)
|
||||||
|
{
|
||||||
|
xfs_agino_t first;
|
||||||
|
xfs_agino_t last;
|
||||||
|
|
||||||
|
xfs_agino_range(mp, agno, &first, &last);
|
||||||
|
return agino >= first && agino <= last;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that an FS inode number pointer neither points outside the
|
||||||
|
* filesystem nor points at static AG metadata.
|
||||||
|
*/
|
||||||
|
bool
|
||||||
|
xfs_verify_ino(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_ino_t ino)
|
||||||
|
{
|
||||||
|
xfs_agnumber_t agno = XFS_INO_TO_AGNO(mp, ino);
|
||||||
|
xfs_agino_t agino = XFS_INO_TO_AGINO(mp, ino);
|
||||||
|
|
||||||
|
if (agno >= mp->m_sb.sb_agcount)
|
||||||
|
return false;
|
||||||
|
if (XFS_AGINO_TO_INO(mp, agno, agino) != ino)
|
||||||
|
return false;
|
||||||
|
return xfs_verify_agino(mp, agno, agino);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Is this an internal inode number? */
|
||||||
|
bool
|
||||||
|
xfs_internal_inum(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_ino_t ino)
|
||||||
|
{
|
||||||
|
return ino == mp->m_sb.sb_rbmino || ino == mp->m_sb.sb_rsumino ||
|
||||||
|
(xfs_sb_version_hasquota(&mp->m_sb) &&
|
||||||
|
xfs_is_quota_inode(&mp->m_sb, ino));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that a directory entry's inode number doesn't point at an internal
|
||||||
|
* inode, empty space, or static AG metadata.
|
||||||
|
*/
|
||||||
|
bool
|
||||||
|
xfs_verify_dir_ino(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_ino_t ino)
|
||||||
|
{
|
||||||
|
if (xfs_internal_inum(mp, ino))
|
||||||
|
return false;
|
||||||
|
return xfs_verify_ino(mp, ino);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that an realtime block number pointer doesn't point off the
|
||||||
|
* end of the realtime device.
|
||||||
|
*/
|
||||||
|
bool
|
||||||
|
xfs_verify_rtbno(
|
||||||
|
struct xfs_mount *mp,
|
||||||
|
xfs_rtblock_t rtbno)
|
||||||
|
{
|
||||||
|
return rtbno < mp->m_sb.sb_rblocks;
|
||||||
|
}
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2005 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_TYPES_H__
|
#ifndef __XFS_TYPES_H__
|
||||||
#define __XFS_TYPES_H__
|
#define __XFS_TYPES_H__
|
||||||
|
@ -159,4 +147,23 @@ typedef struct xfs_bmbt_irec
|
||||||
xfs_exntst_t br_state; /* extent state */
|
xfs_exntst_t br_state; /* extent state */
|
||||||
} xfs_bmbt_irec_t;
|
} xfs_bmbt_irec_t;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Type verifier functions
|
||||||
|
*/
|
||||||
|
struct xfs_mount;
|
||||||
|
|
||||||
|
xfs_agblock_t xfs_ag_block_count(struct xfs_mount *mp, xfs_agnumber_t agno);
|
||||||
|
bool xfs_verify_agbno(struct xfs_mount *mp, xfs_agnumber_t agno,
|
||||||
|
xfs_agblock_t agbno);
|
||||||
|
bool xfs_verify_fsbno(struct xfs_mount *mp, xfs_fsblock_t fsbno);
|
||||||
|
|
||||||
|
void xfs_agino_range(struct xfs_mount *mp, xfs_agnumber_t agno,
|
||||||
|
xfs_agino_t *first, xfs_agino_t *last);
|
||||||
|
bool xfs_verify_agino(struct xfs_mount *mp, xfs_agnumber_t agno,
|
||||||
|
xfs_agino_t agino);
|
||||||
|
bool xfs_verify_ino(struct xfs_mount *mp, xfs_ino_t ino);
|
||||||
|
bool xfs_internal_inum(struct xfs_mount *mp, xfs_ino_t ino);
|
||||||
|
bool xfs_verify_dir_ino(struct xfs_mount *mp, xfs_ino_t ino);
|
||||||
|
bool xfs_verify_rtbno(struct xfs_mount *mp, xfs_rtblock_t rtbno);
|
||||||
|
|
||||||
#endif /* __XFS_TYPES_H__ */
|
#endif /* __XFS_TYPES_H__ */
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
* Copyright (c) 2000-2006 Silicon Graphics, Inc.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SUPPORT_MRLOCK_H__
|
#ifndef __XFS_SUPPORT_MRLOCK_H__
|
||||||
#define __XFS_SUPPORT_MRLOCK_H__
|
#define __XFS_SUPPORT_MRLOCK_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
@ -881,7 +867,7 @@ xfs_scrub_agi(
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check inode counters */
|
/* Check inode counters */
|
||||||
xfs_ialloc_agino_range(mp, agno, &first_agino, &last_agino);
|
xfs_agino_range(mp, agno, &first_agino, &last_agino);
|
||||||
icount = be32_to_cpu(agi->agi_count);
|
icount = be32_to_cpu(agi->agi_count);
|
||||||
if (icount > last_agino - first_agino + 1 ||
|
if (icount > last_agino - first_agino + 1 ||
|
||||||
icount < be32_to_cpu(agi->agi_freecount))
|
icount < be32_to_cpu(agi->agi_freecount))
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2018 Oracle. All Rights Reserved.
|
* Copyright (C) 2018 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SCRUB_BTREE_H__
|
#ifndef __XFS_SCRUB_BTREE_H__
|
||||||
#define __XFS_SCRUB_BTREE_H__
|
#define __XFS_SCRUB_BTREE_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SCRUB_COMMON_H__
|
#ifndef __XFS_SCRUB_COMMON_H__
|
||||||
#define __XFS_SCRUB_COMMON_H__
|
#define __XFS_SCRUB_COMMON_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SCRUB_DABTREE_H__
|
#ifndef __XFS_SCRUB_DABTREE_H__
|
||||||
#define __XFS_SCRUB_DABTREE_H__
|
#define __XFS_SCRUB_DABTREE_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2018 Oracle. All Rights Reserved.
|
* Copyright (C) 2018 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2018 Oracle. All Rights Reserved.
|
* Copyright (C) 2018 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SCRUB_REPAIR_H__
|
#ifndef __XFS_SCRUB_REPAIR_H__
|
||||||
#define __XFS_SCRUB_REPAIR_H__
|
#define __XFS_SCRUB_REPAIR_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#ifndef __XFS_SCRUB_SCRUB_H__
|
#ifndef __XFS_SCRUB_SCRUB_H__
|
||||||
#define __XFS_SCRUB_SCRUB_H__
|
#define __XFS_SCRUB_SCRUB_H__
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#include "xfs.h"
|
#include "xfs.h"
|
||||||
#include "xfs_fs.h"
|
#include "xfs_fs.h"
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
* Copyright (C) 2017 Oracle. All Rights Reserved.
|
||||||
*
|
|
||||||
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
* Author: Darrick J. Wong <darrick.wong@oracle.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it would be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
*/
|
||||||
#undef TRACE_SYSTEM
|
#undef TRACE_SYSTEM
|
||||||
#define TRACE_SYSTEM xfs_scrub
|
#define TRACE_SYSTEM xfs_scrub
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue