Loading...
1/* AFS caching stuff
2 *
3 * Copyright (C) 2008 Red Hat, Inc. All Rights Reserved.
4 * Written by David Howells (dhowells@redhat.com)
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version
9 * 2 of the License, or (at your option) any later version.
10 */
11
12#include <linux/sched.h>
13#include "internal.h"
14
15static enum fscache_checkaux afs_vnode_cache_check_aux(void *cookie_netfs_data,
16 const void *buffer,
17 uint16_t buflen,
18 loff_t object_size);
19
20struct fscache_netfs afs_cache_netfs = {
21 .name = "afs",
22 .version = 2,
23};
24
25struct fscache_cookie_def afs_cell_cache_index_def = {
26 .name = "AFS.cell",
27 .type = FSCACHE_COOKIE_TYPE_INDEX,
28};
29
30struct fscache_cookie_def afs_volume_cache_index_def = {
31 .name = "AFS.volume",
32 .type = FSCACHE_COOKIE_TYPE_INDEX,
33};
34
35struct fscache_cookie_def afs_vnode_cache_index_def = {
36 .name = "AFS.vnode",
37 .type = FSCACHE_COOKIE_TYPE_DATAFILE,
38 .check_aux = afs_vnode_cache_check_aux,
39};
40
41/*
42 * check that the auxiliary data indicates that the entry is still valid
43 */
44static enum fscache_checkaux afs_vnode_cache_check_aux(void *cookie_netfs_data,
45 const void *buffer,
46 uint16_t buflen,
47 loff_t object_size)
48{
49 struct afs_vnode *vnode = cookie_netfs_data;
50 struct afs_vnode_cache_aux aux;
51
52 _enter("{%x,%x,%llx},%p,%u",
53 vnode->fid.vnode, vnode->fid.unique, vnode->status.data_version,
54 buffer, buflen);
55
56 memcpy(&aux, buffer, sizeof(aux));
57
58 /* check the size of the data is what we're expecting */
59 if (buflen != sizeof(aux)) {
60 _leave(" = OBSOLETE [len %hx != %zx]", buflen, sizeof(aux));
61 return FSCACHE_CHECKAUX_OBSOLETE;
62 }
63
64 if (vnode->status.data_version != aux.data_version) {
65 _leave(" = OBSOLETE [vers %llx != %llx]",
66 aux.data_version, vnode->status.data_version);
67 return FSCACHE_CHECKAUX_OBSOLETE;
68 }
69
70 _leave(" = SUCCESS");
71 return FSCACHE_CHECKAUX_OKAY;
72}
1// SPDX-License-Identifier: GPL-2.0-or-later
2/* AFS caching stuff
3 *
4 * Copyright (C) 2008 Red Hat, Inc. All Rights Reserved.
5 * Written by David Howells (dhowells@redhat.com)
6 */
7
8#include <linux/sched.h>
9#include "internal.h"
10
11static enum fscache_checkaux afs_vnode_cache_check_aux(void *cookie_netfs_data,
12 const void *buffer,
13 uint16_t buflen,
14 loff_t object_size);
15
16struct fscache_netfs afs_cache_netfs = {
17 .name = "afs",
18 .version = 2,
19};
20
21struct fscache_cookie_def afs_cell_cache_index_def = {
22 .name = "AFS.cell",
23 .type = FSCACHE_COOKIE_TYPE_INDEX,
24};
25
26struct fscache_cookie_def afs_volume_cache_index_def = {
27 .name = "AFS.volume",
28 .type = FSCACHE_COOKIE_TYPE_INDEX,
29};
30
31struct fscache_cookie_def afs_vnode_cache_index_def = {
32 .name = "AFS.vnode",
33 .type = FSCACHE_COOKIE_TYPE_DATAFILE,
34 .check_aux = afs_vnode_cache_check_aux,
35};
36
37/*
38 * check that the auxiliary data indicates that the entry is still valid
39 */
40static enum fscache_checkaux afs_vnode_cache_check_aux(void *cookie_netfs_data,
41 const void *buffer,
42 uint16_t buflen,
43 loff_t object_size)
44{
45 struct afs_vnode *vnode = cookie_netfs_data;
46 struct afs_vnode_cache_aux aux;
47
48 _enter("{%llx,%x,%llx},%p,%u",
49 vnode->fid.vnode, vnode->fid.unique, vnode->status.data_version,
50 buffer, buflen);
51
52 memcpy(&aux, buffer, sizeof(aux));
53
54 /* check the size of the data is what we're expecting */
55 if (buflen != sizeof(aux)) {
56 _leave(" = OBSOLETE [len %hx != %zx]", buflen, sizeof(aux));
57 return FSCACHE_CHECKAUX_OBSOLETE;
58 }
59
60 if (vnode->status.data_version != aux.data_version) {
61 _leave(" = OBSOLETE [vers %llx != %llx]",
62 aux.data_version, vnode->status.data_version);
63 return FSCACHE_CHECKAUX_OBSOLETE;
64 }
65
66 _leave(" = SUCCESS");
67 return FSCACHE_CHECKAUX_OKAY;
68}