/*
* Copyright 2014 Cray Inc, all rights reserved.
+ *
+ * Copyright (c) 2016, Intel Corporation.
+ *
* Author: Frank Zago.
*
* A few portions are extracted from llapi_layout_test.c
static char mainpath[PATH_MAX];
static const char *maindir = "llapi_fid_test_name_9585766";
-static char fsmountdir[PATH_MAX]; /* Lustre mountpoint */
+static char mnt_dir[PATH_MAX]; /* Lustre mountpoint */
+static int mnt_fd = -1;
static char *lustre_dir; /* Test directory inside Lustre */
/* Cleanup our test directory. */
* file/directory */
static void helper_fid2path(const char *filename, int fd)
{
- lustre_fid fid;
- lustre_fid fid2;
- lustre_fid fid3;
+ struct lu_fid fid;
+ struct lu_fid fid2;
+ struct lu_fid fid3;
char fidstr[FID_LEN + 1];
char path1[PATH_MAX];
char path2[PATH_MAX];
ASSERTF(linkno1 == linkno2, "linknos are different: %d / %d",
linkno1, linkno2);
+ /* Use llapi_fid2path_at() */
+ recno2 = -1;
+ linkno2 = 0;
+ rc = llapi_fid2path_at(mnt_fd, &fid, path2, sizeof(path2),
+ &recno2, &linkno2);
+ ASSERTF(rc == 0, "llapi_fid2path failed for fid %s: %s",
+ fidstr, strerror(-rc));
+
+ /* Make sure both calls to llapi_fid2path returned the same
+ * data. */
+ ASSERTF(strcmp(path1, path2) == 0, "paths are different: '%s' / '%s'",
+ path1, path2);
+ ASSERTF(recno1 == recno2, "recnos are different: %lld / %lld",
+ recno1, recno2);
+ ASSERTF(linkno1 == linkno2, "linknos are different: %d / %d",
+ linkno1, linkno2);
+
/* Try fd2fid and check that the result is still the same. */
if (fd != -1) {
rc = llapi_fd2fid(fd, &fid3);
/* Pass the result back to fid2path and ensure the fid stays
* the same. */
- rc = snprintf(path3, sizeof(path3), "%s/%s", fsmountdir, path1);
+ rc = snprintf(path3, sizeof(path3), "%s/%s", mnt_dir, path1);
ASSERTF((rc > 0 && rc < sizeof(path3)), "invalid name");
rc = llapi_path2fid(path3, &fid2);
ASSERTF(rc == 0, "llapi_path2fid failed for '%s': %s",
{
int rc;
int fd;
- lustre_fid fid;
+ struct lu_fid fid;
char fidstr[FID_LEN + 1];
char path[PATH_MAX];
long long recno;
int fd;
int fd2;
int fd3;
- lustre_fid fid;
+ struct lu_fid fid;
/* Against a volatile file */
rc = mkdir(mainpath, 0);
/* Create subdirectories as long as we can. Each new subdir is
* "/x", so we need at least 3 characters left in testpath. */
while (len <= sizeof(testpath) - 3) {
- strncat(testpath, "/x", 2);
+ strncat(testpath, "/x", sizeof(testpath) - 1);
len += 2;
bool seen;
} links[num_links];
char buf[PATH_MAX];
- char buf2[PATH_MAX];
- lustre_fid fid;
+ char buf2[PATH_MAX * 2];
+ struct lu_fid fid;
char fidstr[FID_LEN + 1];
int rc;
int i;
ASSERTF(rc == 0, "llapi_fid2path failed for fid %s: %s",
fidstr, strerror(-rc));
- snprintf(buf2, sizeof(buf2), "%s/%s", fsmountdir, buf);
+ snprintf(buf2, sizeof(buf2), "%s/%s", mnt_dir, buf);
if (past_link_limit == false) {
/* Find the name in the links that were created */
* type). mainpath must exist. */
static void help_test40(void)
{
- lustre_fid parent_fid;
- lustre_fid fid2;
+ struct lu_fid parent_fid;
+ struct lu_fid fid2;
char buf[PATH_MAX];
int rc;
const int num_links = 100;
struct {
char subdir[PATH_MAX];
- lustre_fid subdir_fid;
+ struct lu_fid subdir_fid;
char filename[PATH_MAX];
bool seen;
} links[num_links];
int i;
int fd;
int linkno;
- lustre_fid parent_fid;
+ struct lu_fid parent_fid;
/* Create the containing directory. */
rc = mkdir(mainpath, 0);
if (lustre_dir == NULL)
lustre_dir = "/mnt/lustre";
- rc = llapi_search_mounts(lustre_dir, 0, fsmountdir, fsname);
+ rc = llapi_search_mounts(lustre_dir, 0, mnt_dir, fsname);
if (rc != 0) {
fprintf(stderr, "Error: %s: not a Lustre filesystem\n",
lustre_dir);
return EXIT_FAILURE;
}
+ mnt_fd = open(mnt_dir, O_RDONLY|O_DIRECTORY);
+ ASSERTF(!(mnt_fd < 0), "cannot open '%s': %s\n", mnt_dir, strerror(errno));
+
/* Play nice with Lustre test scripts. Non-line buffered output
* stream under I/O redirection may appear incorrectly. */
setvbuf(stdout, NULL, _IOLBF, 0);