2019-05-20 20:08:01 +03:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2018-04-06 16:17:24 +03:00
/* AFS fileserver XDR types
*
* Copyright ( C ) 2018 Red Hat , Inc . All Rights Reserved .
* Written by David Howells ( dhowells @ redhat . com )
*/
# ifndef XDR_FS_H
# define XDR_FS_H
struct afs_xdr_AFSFetchStatus {
__be32 if_version ;
# define AFS_FSTATUS_VERSION 1
__be32 type ;
__be32 nlink ;
__be32 size_lo ;
__be32 data_version_lo ;
__be32 author ;
__be32 owner ;
__be32 caller_access ;
__be32 anon_access ;
__be32 mode ;
__be32 parent_vnode ;
__be32 parent_unique ;
__be32 seg_size ;
__be32 mtime_client ;
__be32 mtime_server ;
__be32 group ;
__be32 sync_counter ;
__be32 data_version_hi ;
__be32 lock_count ;
__be32 size_hi ;
__be32 abort_code ;
} __packed ;
2018-04-06 16:17:25 +03:00
# define AFS_DIR_HASHTBL_SIZE 128
# define AFS_DIR_DIRENT_SIZE 32
# define AFS_DIR_SLOTS_PER_BLOCK 64
# define AFS_DIR_BLOCK_SIZE 2048
# define AFS_DIR_BLOCKS_PER_PAGE (PAGE_SIZE / AFS_DIR_BLOCK_SIZE)
# define AFS_DIR_MAX_SLOTS 65536
# define AFS_DIR_BLOCKS_WITH_CTR 128
# define AFS_DIR_MAX_BLOCKS 1023
# define AFS_DIR_RESV_BLOCKS 1
# define AFS_DIR_RESV_BLOCKS0 13
/*
* Directory entry structure .
*/
2018-04-06 16:17:25 +03:00
union afs_xdr_dirent {
2018-04-06 16:17:25 +03:00
struct {
2018-04-06 16:17:25 +03:00
u8 valid ;
u8 unused [ 1 ] ;
2018-04-06 16:17:25 +03:00
__be16 hash_next ;
__be32 vnode ;
__be32 unique ;
2020-12-22 01:37:58 +03:00
u8 name [ ] ;
/* When determining the number of dirent slots needed to
* represent a directory entry , name should be assumed to be 16
* bytes , due to a now - standardised ( mis ) calculation , but it is
2020-12-23 13:39:57 +03:00
* in fact 20 bytes in size . afs_dir_calc_slots ( ) should be
* used for this .
2020-12-22 01:37:58 +03:00
*
* For names longer than ( 16 or ) 20 bytes , extra slots should
* be annexed to this one using the extended_name format .
*/
2018-04-06 16:17:25 +03:00
} u ;
2018-04-06 16:17:25 +03:00
u8 extended_name [ 32 ] ;
} __packed ;
2018-04-06 16:17:25 +03:00
/*
2018-04-06 16:17:25 +03:00
* Directory block header ( one at the beginning of every 2048 - byte block ) .
2018-04-06 16:17:25 +03:00
*/
2018-04-06 16:17:25 +03:00
struct afs_xdr_dir_hdr {
2018-04-06 16:17:25 +03:00
__be16 npages ;
__be16 magic ;
# define AFS_DIR_MAGIC htons(1234)
2018-04-06 16:17:25 +03:00
u8 reserved ;
u8 bitmap [ 8 ] ;
u8 pad [ 19 ] ;
} __packed ;
2018-04-06 16:17:25 +03:00
/*
* Directory block layout
*/
2018-04-06 16:17:25 +03:00
union afs_xdr_dir_block {
struct afs_xdr_dir_hdr hdr ;
2018-04-06 16:17:25 +03:00
struct {
2018-04-06 16:17:25 +03:00
struct afs_xdr_dir_hdr hdr ;
u8 alloc_ctrs [ AFS_DIR_MAX_BLOCKS ] ;
2018-04-06 16:17:25 +03:00
__be16 hashtable [ AFS_DIR_HASHTBL_SIZE ] ;
2018-04-06 16:17:25 +03:00
} meta ;
2018-04-06 16:17:25 +03:00
2018-04-06 16:17:25 +03:00
union afs_xdr_dirent dirents [ AFS_DIR_SLOTS_PER_BLOCK ] ;
} __packed ;
2018-04-06 16:17:25 +03:00
/*
* Directory layout on a linux VM page .
*/
2018-04-06 16:17:25 +03:00
struct afs_xdr_dir_page {
union afs_xdr_dir_block blocks [ AFS_DIR_BLOCKS_PER_PAGE ] ;
2018-04-06 16:17:25 +03:00
} ;
2020-12-23 13:39:57 +03:00
/*
* Calculate the number of dirent slots required for any given name length .
* The calculation is made assuming the part of the name in the first slot is
* 16 bytes , rather than 20 , but this miscalculation is now standardised .
*/
static inline unsigned int afs_dir_calc_slots ( size_t name_len )
{
name_len + + ; /* NUL-terminated */
return 1 + ( ( name_len + 15 ) / AFS_DIR_DIRENT_SIZE ) ;
}
2018-04-06 16:17:24 +03:00
# endif /* XDR_FS_H */