From fd0f1f49f27b5f92547a0d15e23efd3b2e46376d Mon Sep 17 00:00:00 2001 From: Jeffrey Altman Date: Thu, 7 May 2009 16:02:53 +0000 Subject: [PATCH] windows-fs-path-in-afs-20090507 LICENSE MIT Switch the PathInAfs test to use VIOCGETFID instead of VIOC_GET_CELL_NAME so that the literal option can be used. --- src/WINNT/afsd/fs.c | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/src/WINNT/afsd/fs.c b/src/WINNT/afsd/fs.c index e47dd5a427..c87a27a614 100644 --- a/src/WINNT/afsd/fs.c +++ b/src/WINNT/afsd/fs.c @@ -246,13 +246,20 @@ static int InAFS(char *apath) { struct ViceIoctl blob; + cm_ioctlQueryOptions_t options; + cm_fid_t fid; afs_int32 code; - blob.in_size = 0; - blob.out_size = MAXSIZE; - blob.out = space; + memset(&options, 0, sizeof(options)); + options.size = sizeof(options); + options.field_flags |= CM_IOCTL_QOPTS_FIELD_LITERAL; + options.literal = 1; + blob.in_size = options.size; /* no variable length data */ + blob.in = &options; + blob.out_size = sizeof(cm_fid_t); + blob.out = (char *) &fid; - code = pioctl_utf8(apath, VIOC_FILE_CELL_NAME, &blob, 1); + code = pioctl_utf8(apath, VIOCGETFID, &blob, 1); if (code) { if ((errno == EINVAL) || (errno == ENOENT)) return 0;