123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- /* SPDX-License-Identifier: GPL-2.0 */
- /*
- * (C) 2001 Clemson University and The University of Chicago
- *
- * See COPYING in top-level directory.
- */
- /*
- * Definitions of downcalls used in Linux kernel module.
- */
- #ifndef __DOWNCALL_H
- #define __DOWNCALL_H
- /*
- * Sanitized the device-client core interaction
- * for clean 32-64 bit usage
- */
- struct orangefs_io_response {
- __s64 amt_complete;
- };
- struct orangefs_lookup_response {
- struct orangefs_object_kref refn;
- };
- struct orangefs_create_response {
- struct orangefs_object_kref refn;
- };
- struct orangefs_symlink_response {
- struct orangefs_object_kref refn;
- };
- struct orangefs_getattr_response {
- struct ORANGEFS_sys_attr_s attributes;
- char link_target[ORANGEFS_NAME_MAX];
- };
- struct orangefs_mkdir_response {
- struct orangefs_object_kref refn;
- };
- struct orangefs_statfs_response {
- __s64 block_size;
- __s64 blocks_total;
- __s64 blocks_avail;
- __s64 files_total;
- __s64 files_avail;
- };
- struct orangefs_fs_mount_response {
- __s32 fs_id;
- __s32 id;
- struct orangefs_khandle root_khandle;
- };
- /* the getxattr response is the attribute value */
- struct orangefs_getxattr_response {
- __s32 val_sz;
- __s32 __pad1;
- char val[ORANGEFS_MAX_XATTR_VALUELEN];
- };
- /* the listxattr response is an array of attribute names */
- struct orangefs_listxattr_response {
- __s32 returned_count;
- __s32 __pad1;
- __u64 token;
- char key[ORANGEFS_MAX_XATTR_LISTLEN * ORANGEFS_MAX_XATTR_NAMELEN];
- __s32 keylen;
- __s32 __pad2;
- __s32 lengths[ORANGEFS_MAX_XATTR_LISTLEN];
- };
- struct orangefs_param_response {
- union {
- __s64 value64;
- __s32 value32[2];
- } u;
- };
- #define PERF_COUNT_BUF_SIZE 4096
- struct orangefs_perf_count_response {
- char buffer[PERF_COUNT_BUF_SIZE];
- };
- #define FS_KEY_BUF_SIZE 4096
- struct orangefs_fs_key_response {
- __s32 fs_keylen;
- __s32 __pad1;
- char fs_key[FS_KEY_BUF_SIZE];
- };
- /* 2.9.6 */
- struct orangefs_features_response {
- __u64 features;
- };
- struct orangefs_downcall_s {
- __s32 type;
- __s32 status;
- /* currently trailer is used only by readdir */
- __s64 trailer_size;
- char *trailer_buf;
- union {
- struct orangefs_io_response io;
- struct orangefs_lookup_response lookup;
- struct orangefs_create_response create;
- struct orangefs_symlink_response sym;
- struct orangefs_getattr_response getattr;
- struct orangefs_mkdir_response mkdir;
- struct orangefs_statfs_response statfs;
- struct orangefs_fs_mount_response fs_mount;
- struct orangefs_getxattr_response getxattr;
- struct orangefs_listxattr_response listxattr;
- struct orangefs_param_response param;
- struct orangefs_perf_count_response perf_count;
- struct orangefs_fs_key_response fs_key;
- struct orangefs_features_response features;
- } resp;
- };
- /*
- * The readdir response comes in the trailer. It is followed by the
- * directory entries as described in dir.c.
- */
- struct orangefs_readdir_response_s {
- __u64 token;
- __u64 directory_version;
- __u32 __pad2;
- __u32 orangefs_dirent_outcount;
- };
- #endif /* __DOWNCALL_H */
|