162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (c) 2000-2001 Christoph Hellwig.
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci/*
762306a36Sopenharmony_ci * Veritas filesystem driver - shared subroutines.
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci#include <linux/fs.h>
1062306a36Sopenharmony_ci#include <linux/buffer_head.h>
1162306a36Sopenharmony_ci#include <linux/kernel.h>
1262306a36Sopenharmony_ci#include <linux/pagemap.h>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci#include "vxfs_extern.h"
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_cistatic int		vxfs_read_folio(struct file *, struct folio *);
1862306a36Sopenharmony_cistatic sector_t		vxfs_bmap(struct address_space *, sector_t);
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ciconst struct address_space_operations vxfs_aops = {
2162306a36Sopenharmony_ci	.read_folio =		vxfs_read_folio,
2262306a36Sopenharmony_ci	.bmap =			vxfs_bmap,
2362306a36Sopenharmony_ci};
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ciinline void
2662306a36Sopenharmony_civxfs_put_page(struct page *pp)
2762306a36Sopenharmony_ci{
2862306a36Sopenharmony_ci	kunmap(pp);
2962306a36Sopenharmony_ci	put_page(pp);
3062306a36Sopenharmony_ci}
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci/**
3362306a36Sopenharmony_ci * vxfs_get_page - read a page into memory.
3462306a36Sopenharmony_ci * @mapping:	mapping to read from
3562306a36Sopenharmony_ci * @n:		page number
3662306a36Sopenharmony_ci *
3762306a36Sopenharmony_ci * Description:
3862306a36Sopenharmony_ci *   vxfs_get_page reads the @n th page of @ip into the pagecache.
3962306a36Sopenharmony_ci *
4062306a36Sopenharmony_ci * Returns:
4162306a36Sopenharmony_ci *   The wanted page on success, else a NULL pointer.
4262306a36Sopenharmony_ci */
4362306a36Sopenharmony_cistruct page *
4462306a36Sopenharmony_civxfs_get_page(struct address_space *mapping, u_long n)
4562306a36Sopenharmony_ci{
4662306a36Sopenharmony_ci	struct page *			pp;
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci	pp = read_mapping_page(mapping, n, NULL);
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci	if (!IS_ERR(pp)) {
5162306a36Sopenharmony_ci		kmap(pp);
5262306a36Sopenharmony_ci		/** if (!PageChecked(pp)) **/
5362306a36Sopenharmony_ci			/** vxfs_check_page(pp); **/
5462306a36Sopenharmony_ci	}
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ci	return (pp);
5762306a36Sopenharmony_ci}
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci/**
6062306a36Sopenharmony_ci * vxfs_bread - read buffer for a give inode,block tuple
6162306a36Sopenharmony_ci * @ip:		inode
6262306a36Sopenharmony_ci * @block:	logical block
6362306a36Sopenharmony_ci *
6462306a36Sopenharmony_ci * Description:
6562306a36Sopenharmony_ci *   The vxfs_bread function reads block no @block  of
6662306a36Sopenharmony_ci *   @ip into the buffercache.
6762306a36Sopenharmony_ci *
6862306a36Sopenharmony_ci * Returns:
6962306a36Sopenharmony_ci *   The resulting &struct buffer_head.
7062306a36Sopenharmony_ci */
7162306a36Sopenharmony_cistruct buffer_head *
7262306a36Sopenharmony_civxfs_bread(struct inode *ip, int block)
7362306a36Sopenharmony_ci{
7462306a36Sopenharmony_ci	struct buffer_head	*bp;
7562306a36Sopenharmony_ci	daddr_t			pblock;
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ci	pblock = vxfs_bmap1(ip, block);
7862306a36Sopenharmony_ci	bp = sb_bread(ip->i_sb, pblock);
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci	return (bp);
8162306a36Sopenharmony_ci}
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci/**
8462306a36Sopenharmony_ci * vxfs_getblk - locate buffer for given inode,block tuple
8562306a36Sopenharmony_ci * @ip:		inode
8662306a36Sopenharmony_ci * @iblock:	logical block
8762306a36Sopenharmony_ci * @bp:		buffer skeleton
8862306a36Sopenharmony_ci * @create:	%TRUE if blocks may be newly allocated.
8962306a36Sopenharmony_ci *
9062306a36Sopenharmony_ci * Description:
9162306a36Sopenharmony_ci *   The vxfs_getblk function fills @bp with the right physical
9262306a36Sopenharmony_ci *   block and device number to perform a lowlevel read/write on
9362306a36Sopenharmony_ci *   it.
9462306a36Sopenharmony_ci *
9562306a36Sopenharmony_ci * Returns:
9662306a36Sopenharmony_ci *   Zero on success, else a negativ error code (-EIO).
9762306a36Sopenharmony_ci */
9862306a36Sopenharmony_cistatic int
9962306a36Sopenharmony_civxfs_getblk(struct inode *ip, sector_t iblock,
10062306a36Sopenharmony_ci	    struct buffer_head *bp, int create)
10162306a36Sopenharmony_ci{
10262306a36Sopenharmony_ci	daddr_t			pblock;
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci	pblock = vxfs_bmap1(ip, iblock);
10562306a36Sopenharmony_ci	if (pblock != 0) {
10662306a36Sopenharmony_ci		map_bh(bp, ip->i_sb, pblock);
10762306a36Sopenharmony_ci		return 0;
10862306a36Sopenharmony_ci	}
10962306a36Sopenharmony_ci
11062306a36Sopenharmony_ci	return -EIO;
11162306a36Sopenharmony_ci}
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ci/**
11462306a36Sopenharmony_ci * vxfs_read_folio - read one page synchronously into the pagecache
11562306a36Sopenharmony_ci * @file:	file context (unused)
11662306a36Sopenharmony_ci * @folio:	folio to fill in.
11762306a36Sopenharmony_ci *
11862306a36Sopenharmony_ci * Description:
11962306a36Sopenharmony_ci *   The vxfs_read_folio routine reads @folio synchronously into the
12062306a36Sopenharmony_ci *   pagecache.
12162306a36Sopenharmony_ci *
12262306a36Sopenharmony_ci * Returns:
12362306a36Sopenharmony_ci *   Zero on success, else a negative error code.
12462306a36Sopenharmony_ci *
12562306a36Sopenharmony_ci * Locking status:
12662306a36Sopenharmony_ci *   @folio is locked and will be unlocked.
12762306a36Sopenharmony_ci */
12862306a36Sopenharmony_cistatic int vxfs_read_folio(struct file *file, struct folio *folio)
12962306a36Sopenharmony_ci{
13062306a36Sopenharmony_ci	return block_read_full_folio(folio, vxfs_getblk);
13162306a36Sopenharmony_ci}
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci/**
13462306a36Sopenharmony_ci * vxfs_bmap - perform logical to physical block mapping
13562306a36Sopenharmony_ci * @mapping:	logical to physical mapping to use
13662306a36Sopenharmony_ci * @block:	logical block (relative to @mapping).
13762306a36Sopenharmony_ci *
13862306a36Sopenharmony_ci * Description:
13962306a36Sopenharmony_ci *   Vxfs_bmap find out the corresponding phsical block to the
14062306a36Sopenharmony_ci *   @mapping, @block pair.
14162306a36Sopenharmony_ci *
14262306a36Sopenharmony_ci * Returns:
14362306a36Sopenharmony_ci *   Physical block number on success, else Zero.
14462306a36Sopenharmony_ci *
14562306a36Sopenharmony_ci * Locking status:
14662306a36Sopenharmony_ci *   We are under the bkl.
14762306a36Sopenharmony_ci */
14862306a36Sopenharmony_cistatic sector_t
14962306a36Sopenharmony_civxfs_bmap(struct address_space *mapping, sector_t block)
15062306a36Sopenharmony_ci{
15162306a36Sopenharmony_ci	return generic_block_bmap(mapping, block, vxfs_getblk);
15262306a36Sopenharmony_ci}
153