b908fe6b2d
Add support for the CB.GetCapabilities operation with which the fileserver can ask the client for the following information: (1) The list of network interfaces it has available as IPv4 address + netmask plus the MTUs. (2) The client's UUID. (3) The extended capabilities of the client, for which the only current one is unified error mapping (abort code interpretation). To support this, the patch adds the following routines to AFS: (1) A function to iterate through all the network interfaces using RTNETLINK to extract IPv4 addresses and MTUs. (2) A function to iterate through all the network interfaces using RTNETLINK to pull out the MAC address of the lowest index interface to use in UUID construction. Signed-off-by: David Howells <dhowells@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
31 lines
1.1 KiB
C
31 lines
1.1 KiB
C
/* AFS Cache Manager definitions
|
|
*
|
|
* Copyright (C) 2007 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.
|
|
*/
|
|
|
|
#ifndef AFS_CM_H
|
|
#define AFS_CM_H
|
|
|
|
#define AFS_CM_PORT 7001 /* AFS file server port */
|
|
#define CM_SERVICE 1 /* AFS File Service ID */
|
|
|
|
enum AFS_CM_Operations {
|
|
CBCallBack = 204, /* break callback promises */
|
|
CBInitCallBackState = 205, /* initialise callback state */
|
|
CBProbe = 206, /* probe client */
|
|
CBGetLock = 207, /* get contents of CM lock table */
|
|
CBGetCE = 208, /* get cache file description */
|
|
CBGetXStatsVersion = 209, /* get version of extended statistics */
|
|
CBGetXStats = 210, /* get contents of extended statistics data */
|
|
CBGetCapabilities = 65538, /* get client capabilities */
|
|
};
|
|
|
|
#define AFS_CAP_ERROR_TRANSLATION 0x1
|
|
|
|
#endif /* AFS_FS_H */
|