blob: 8ca8681645077d0bd86ff748462328a8718c1735 [file] [log] [blame]
Thomas Gleixnerb4d0d232019-05-20 19:08:01 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
David Howellsdd9fbcb2018-04-06 14:17:24 +01002/* AFS fileserver XDR types
3 *
4 * Copyright (C) 2018 Red Hat, Inc. All Rights Reserved.
5 * Written by David Howells (dhowells@redhat.com)
David Howellsdd9fbcb2018-04-06 14:17:24 +01006 */
7
8#ifndef XDR_FS_H
9#define XDR_FS_H
10
11struct afs_xdr_AFSFetchStatus {
12 __be32 if_version;
13#define AFS_FSTATUS_VERSION 1
14 __be32 type;
15 __be32 nlink;
16 __be32 size_lo;
17 __be32 data_version_lo;
18 __be32 author;
19 __be32 owner;
20 __be32 caller_access;
21 __be32 anon_access;
22 __be32 mode;
23 __be32 parent_vnode;
24 __be32 parent_unique;
25 __be32 seg_size;
26 __be32 mtime_client;
27 __be32 mtime_server;
28 __be32 group;
29 __be32 sync_counter;
30 __be32 data_version_hi;
31 __be32 lock_count;
32 __be32 size_hi;
33 __be32 abort_code;
34} __packed;
35
David Howells4ea219a2018-04-06 14:17:25 +010036#define AFS_DIR_HASHTBL_SIZE 128
37#define AFS_DIR_DIRENT_SIZE 32
38#define AFS_DIR_SLOTS_PER_BLOCK 64
39#define AFS_DIR_BLOCK_SIZE 2048
40#define AFS_DIR_BLOCKS_PER_PAGE (PAGE_SIZE / AFS_DIR_BLOCK_SIZE)
41#define AFS_DIR_MAX_SLOTS 65536
42#define AFS_DIR_BLOCKS_WITH_CTR 128
43#define AFS_DIR_MAX_BLOCKS 1023
44#define AFS_DIR_RESV_BLOCKS 1
45#define AFS_DIR_RESV_BLOCKS0 13
46
47/*
48 * Directory entry structure.
49 */
David Howells00317632018-04-06 14:17:25 +010050union afs_xdr_dirent {
David Howells4ea219a2018-04-06 14:17:25 +010051 struct {
David Howells00317632018-04-06 14:17:25 +010052 u8 valid;
53 u8 unused[1];
David Howells4ea219a2018-04-06 14:17:25 +010054 __be16 hash_next;
55 __be32 vnode;
56 __be32 unique;
David Howells26982a82020-12-21 22:37:58 +000057 u8 name[];
58 /* When determining the number of dirent slots needed to
59 * represent a directory entry, name should be assumed to be 16
60 * bytes, due to a now-standardised (mis)calculation, but it is
David Howells366911c2020-12-23 10:39:57 +000061 * in fact 20 bytes in size. afs_dir_calc_slots() should be
62 * used for this.
David Howells26982a82020-12-21 22:37:58 +000063 *
64 * For names longer than (16 or) 20 bytes, extra slots should
65 * be annexed to this one using the extended_name format.
66 */
David Howells4ea219a2018-04-06 14:17:25 +010067 } u;
David Howells00317632018-04-06 14:17:25 +010068 u8 extended_name[32];
69} __packed;
David Howells4ea219a2018-04-06 14:17:25 +010070
71/*
David Howells00317632018-04-06 14:17:25 +010072 * Directory block header (one at the beginning of every 2048-byte block).
David Howells4ea219a2018-04-06 14:17:25 +010073 */
David Howells00317632018-04-06 14:17:25 +010074struct afs_xdr_dir_hdr {
David Howells4ea219a2018-04-06 14:17:25 +010075 __be16 npages;
76 __be16 magic;
77#define AFS_DIR_MAGIC htons(1234)
David Howells00317632018-04-06 14:17:25 +010078 u8 reserved;
79 u8 bitmap[8];
80 u8 pad[19];
81} __packed;
David Howells4ea219a2018-04-06 14:17:25 +010082
83/*
84 * Directory block layout
85 */
David Howells00317632018-04-06 14:17:25 +010086union afs_xdr_dir_block {
87 struct afs_xdr_dir_hdr hdr;
David Howells4ea219a2018-04-06 14:17:25 +010088
89 struct {
David Howells00317632018-04-06 14:17:25 +010090 struct afs_xdr_dir_hdr hdr;
91 u8 alloc_ctrs[AFS_DIR_MAX_BLOCKS];
David Howells4ea219a2018-04-06 14:17:25 +010092 __be16 hashtable[AFS_DIR_HASHTBL_SIZE];
David Howells00317632018-04-06 14:17:25 +010093 } meta;
David Howells4ea219a2018-04-06 14:17:25 +010094
David Howells00317632018-04-06 14:17:25 +010095 union afs_xdr_dirent dirents[AFS_DIR_SLOTS_PER_BLOCK];
96} __packed;
David Howells4ea219a2018-04-06 14:17:25 +010097
98/*
99 * Directory layout on a linux VM page.
100 */
David Howells00317632018-04-06 14:17:25 +0100101struct afs_xdr_dir_page {
102 union afs_xdr_dir_block blocks[AFS_DIR_BLOCKS_PER_PAGE];
David Howells4ea219a2018-04-06 14:17:25 +0100103};
104
David Howells366911c2020-12-23 10:39:57 +0000105/*
106 * Calculate the number of dirent slots required for any given name length.
107 * The calculation is made assuming the part of the name in the first slot is
108 * 16 bytes, rather than 20, but this miscalculation is now standardised.
109 */
110static inline unsigned int afs_dir_calc_slots(size_t name_len)
111{
112 name_len++; /* NUL-terminated */
113 return 1 + ((name_len + 15) / AFS_DIR_DIRENT_SIZE);
114}
115
David Howellsdd9fbcb2018-04-06 14:17:24 +0100116#endif /* XDR_FS_H */