volume.h 4.4 KB
Newer Older
D
David Howells 已提交
1
/* AFS volume management
L
Linus Torvalds 已提交
2 3 4 5 6 7 8 9 10 11
 *
 * Copyright (C) 2002 Red Hat, Inc. All Rights Reserved.
 * Written by David Howells (dhowells@redhat.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.
 */

D
David Howells 已提交
12 13
#ifndef AFS_VOLUME_H
#define AFS_VOLUME_H
L
Linus Torvalds 已提交
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30

#include "types.h"
#include "fsclient.h"
#include "kafstimod.h"
#include "kafsasyncd.h"
#include "cache.h"

typedef enum {
	AFS_VLUPD_SLEEP,		/* sleeping waiting for update timer to fire */
	AFS_VLUPD_PENDING,		/* on pending queue */
	AFS_VLUPD_INPROGRESS,		/* op in progress */
	AFS_VLUPD_BUSYSLEEP,		/* sleeping because server returned EBUSY */
} __attribute__((packed)) afs_vlocation_upd_t;

/*
 * entry in the cached volume location catalogue
 */
D
David Howells 已提交
31
struct afs_cache_vlocation {
L
Linus Torvalds 已提交
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
	uint8_t			name[64];	/* volume name (lowercase, padded with NULs) */
	uint8_t			nservers;	/* number of entries used in servers[] */
	uint8_t			vidmask;	/* voltype mask for vid[] */
	uint8_t			srvtmask[8];	/* voltype masks for servers[] */
#define AFS_VOL_VTM_RW	0x01 /* R/W version of the volume is available (on this server) */
#define AFS_VOL_VTM_RO	0x02 /* R/O version of the volume is available (on this server) */
#define AFS_VOL_VTM_BAK	0x04 /* backup version of the volume is available (on this server) */

	afs_volid_t		vid[3];		/* volume IDs for R/W, R/O and Bak volumes */
	struct in_addr		servers[8];	/* fileserver addresses */
	time_t			rtime;		/* last retrieval time */
};

#ifdef AFS_CACHING_SUPPORT
extern struct cachefs_index_def afs_vlocation_cache_index_def;
#endif

/*
 * volume -> vnode hash table entry
 */
D
David Howells 已提交
52
struct afs_cache_vhash {
L
Linus Torvalds 已提交
53 54 55 56 57 58 59 60 61 62 63
	afs_voltype_t		vtype;		/* which volume variation */
	uint8_t			hash_bucket;	/* which hash bucket this represents */
} __attribute__((packed));

#ifdef AFS_CACHING_SUPPORT
extern struct cachefs_index_def afs_volume_cache_index_def;
#endif

/*
 * AFS volume location record
 */
D
David Howells 已提交
64
struct afs_vlocation {
L
Linus Torvalds 已提交
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
	atomic_t		usage;
	struct list_head	link;		/* link in cell volume location list */
	struct afs_timer	timeout;	/* decaching timer */
	struct afs_cell		*cell;		/* cell to which volume belongs */
#ifdef AFS_CACHING_SUPPORT
	struct cachefs_cookie	*cache;		/* caching cookie */
#endif
	struct afs_cache_vlocation vldb;	/* volume information DB record */
	struct afs_volume	*vols[3];	/* volume access record pointer (index by type) */
	rwlock_t		lock;		/* access lock */
	unsigned long		read_jif;	/* time at which last read from vlserver */
	struct afs_timer	upd_timer;	/* update timer */
	struct afs_async_op	upd_op;		/* update operation */
	afs_vlocation_upd_t	upd_state;	/* update state */
	unsigned short		upd_first_svix;	/* first server index during update */
	unsigned short		upd_curr_svix;	/* current server index during update */
	unsigned short		upd_rej_cnt;	/* ENOMEDIUM count during update */
	unsigned short		upd_busy_cnt;	/* EBUSY count during update */
	unsigned short		valid;		/* T if valid */
};

D
David Howells 已提交
86 87
extern int afs_vlocation_lookup(struct afs_cell *, const char *, unsigned,
				struct afs_vlocation **);
L
Linus Torvalds 已提交
88 89 90

#define afs_get_vlocation(V) do { atomic_inc(&(V)->usage); } while(0)

D
David Howells 已提交
91 92
extern void afs_put_vlocation(struct afs_vlocation *);
extern void afs_vlocation_do_timeout(struct afs_vlocation *);
L
Linus Torvalds 已提交
93 94 95 96

/*
 * AFS volume access record
 */
D
David Howells 已提交
97
struct afs_volume {
L
Linus Torvalds 已提交
98 99 100 101 102 103 104
	atomic_t		usage;
	struct afs_cell		*cell;		/* cell to which belongs (unrefd ptr) */
	struct afs_vlocation	*vlocation;	/* volume location */
#ifdef AFS_CACHING_SUPPORT
	struct cachefs_cookie	*cache;		/* caching cookie */
#endif
	afs_volid_t		vid;		/* volume ID */
105
	afs_voltype_t		type;		/* type of volume */
L
Linus Torvalds 已提交
106 107 108 109 110 111 112
	char			type_force;	/* force volume type (suppress R/O -> R/W) */
	unsigned short		nservers;	/* number of server slots filled */
	unsigned short		rjservers;	/* number of servers discarded due to -ENOMEDIUM */
	struct afs_server	*servers[8];	/* servers on which volume resides (ordered) */
	struct rw_semaphore	server_sem;	/* lock for accessing current server */
};

D
David Howells 已提交
113 114
extern int afs_volume_lookup(const char *, struct afs_cell *, int,
			     struct afs_volume **);
L
Linus Torvalds 已提交
115 116 117

#define afs_get_volume(V) do { atomic_inc(&(V)->usage); } while(0)

D
David Howells 已提交
118
extern void afs_put_volume(struct afs_volume *);
L
Linus Torvalds 已提交
119

D
David Howells 已提交
120 121
extern int afs_volume_pick_fileserver(struct afs_volume *,
				      struct afs_server **);
L
Linus Torvalds 已提交
122

D
David Howells 已提交
123 124
extern int afs_volume_release_fileserver(struct afs_volume *,
					 struct afs_server *, int);
L
Linus Torvalds 已提交
125

D
David Howells 已提交
126
#endif /* AFS_VOLUME_H */