2019-05-24 18:04:05 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-12-16 06:31:24 +08:00
|
|
|
/* -*- mode: c; c-basic-offset: 8; -*-
|
|
|
|
* vim: noexpandtab sw=8 ts=8 sts=0:
|
|
|
|
*
|
|
|
|
* dcache.h
|
|
|
|
*
|
|
|
|
* Function prototypes
|
|
|
|
*
|
|
|
|
* Copyright (C) 2002, 2004 Oracle. All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OCFS2_DCACHE_H
|
|
|
|
#define OCFS2_DCACHE_H
|
|
|
|
|
2009-02-20 14:00:26 +08:00
|
|
|
extern const struct dentry_operations ocfs2_dentry_ops;
|
2005-12-16 06:31:24 +08:00
|
|
|
|
2006-09-09 05:14:34 +08:00
|
|
|
struct ocfs2_dentry_lock {
|
|
|
|
unsigned int dl_count;
|
2014-04-04 05:46:59 +08:00
|
|
|
u64 dl_parent_blkno;
|
2006-09-09 05:14:34 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The ocfs2_dentry_lock keeps an inode reference until
|
|
|
|
* dl_lockres has been destroyed. This is usually done in
|
|
|
|
* ->d_iput() anyway, so there should be minimal impact.
|
|
|
|
*/
|
|
|
|
struct inode *dl_inode;
|
|
|
|
struct ocfs2_lock_res dl_lockres;
|
|
|
|
};
|
|
|
|
|
2006-09-09 05:43:18 +08:00
|
|
|
int ocfs2_dentry_attach_lock(struct dentry *dentry, struct inode *inode,
|
2006-09-22 07:51:28 +08:00
|
|
|
u64 parent_blkno);
|
2006-09-09 05:43:18 +08:00
|
|
|
|
|
|
|
void ocfs2_dentry_lock_put(struct ocfs2_super *osb,
|
|
|
|
struct ocfs2_dentry_lock *dl);
|
|
|
|
|
|
|
|
struct dentry *ocfs2_find_local_alias(struct inode *inode, u64 parent_blkno,
|
|
|
|
int skip_unhashed);
|
|
|
|
|
|
|
|
void ocfs2_dentry_move(struct dentry *dentry, struct dentry *target,
|
|
|
|
struct inode *old_dir, struct inode *new_dir);
|
2006-09-09 05:14:34 +08:00
|
|
|
|
|
|
|
extern spinlock_t dentry_attach_lock;
|
2010-06-28 23:04:32 +08:00
|
|
|
void ocfs2_dentry_attach_gen(struct dentry *dentry);
|
2006-09-09 05:14:34 +08:00
|
|
|
|
2005-12-16 06:31:24 +08:00
|
|
|
#endif /* OCFS2_DCACHE_H */
|