предохранитель: ошибка создания потока: ресурс временно недоступен - PullRequest
0 голосов
/ 24 марта 2019

После записи getattr и readdir функций для простейшей файловой системы fuse, я получаю fuse: ошибка создания потока: Ресурс временно недоступен. , Я хотел бы знать, где в моем коде я допустил ошибку

Я уже ищу это, но не могу найти ничего, что меня устраивает. Мне кажется, что он превысил предел потока, но я не знаю, как это исправить. Я скомпилировал это с

$ gcc passthrough.c -o passthrough `pkg-config fuse --cflags --libs`
passthrough.c:65:2: warning: initialization from incompatible pointer type [enabled by default]
  .getattr = e_getattr,
  ^
passthrough.c:65:2: warning: (near initialization for 'oper.getattr') [enabled by default]

Вот исходный код программы

#define FUSE_USE_VERSION 26

#include <fuse.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <dirent.h>
#include <errno.h>
#include <sys/time.h>
#include <limits.h>

char rootdir[100];

void get_fullpath(char fpath[PATH_MAX], const char *path){
    strcpy(fpath,rootdir);
    strncat(fpath,path,PATH_MAX);
    printf("[fullpath] file: %s\n",fpath);
}

int e_getattr(const char *path, struct stat *stbuf, struct fuse_file_info *fi){
    (void)fi;
    int res;

    char fpath[PATH_MAX];
    get_fullpath(fpath,path);

    printf("[getattr] file: %s\n",fpath);

    res = lstat(fpath,stbuf);
    if (res == -1)
        return -errno;
    return 0;
}

int e_readdir(const char *path, void *buf, fuse_fill_dir_t filler, off_t offset, struct fuse_file_info *fi){
    DIR *dp;
    struct dirent *de;

    (void)offset;
    (void)fi;

    char fpath[PATH_MAX];
    get_fullpath(fpath,path);
    printf("[readdir] file: %s\n",fpath);

    dp = opendir(fpath);
    if (dp == NULL)
        return -errno;

    while ((de = readdir(dp)) != NULL){
        struct stat st;
        memset(&st,0,sizeof(st));
        st.st_ino = de->d_ino;
        st.st_mode = de->d_type << 12;
        if (filler(buf,de->d_name,&st,0))
            break;
    }
    closedir(dp);
    return 0;
}

struct fuse_operations oper = {
    .getattr = e_getattr,
    .readdir = e_readdir,
};

int main(int argc, char * argv[]){
    umask(0);
    realpath(argv[2],rootdir);
    printf("Real path is %s\n",rootdir);
    return fuse_main(argc,argv,&oper,NULL);
}

А вот результат, который я получаю

[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/
[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/
[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/
[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/
[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/
[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/
...
...
...
[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/
fuse: error creating thread: Resource temporarily unavailable
[fullpath] file: /home/echo/passthrough/test/
[getattr] file: /home/echo/passthrough/test/

1 Ответ

0 голосов
/ 24 марта 2019

проблема в функции: e_getattr() Это должно быть записано как:

static int e_getattr(const char *path, struct stat *stbuf )
{
    int res;

    char fpath[PATH_MAX];
    get_fullpath(fpath,path);

    printf("[getattr] file: %s\n",fpath);

    res = lstat(fpath,stbuf);
    if (res == -1)
        return -ENONET;
    return 0;
}

Обратите внимание на добавленный модификатор static

Обратите внимание на удаление третьего функционального параметра

Обратите внимание на изменение возврата (при ошибке) на -ENONET

Также в списке включенных заголовочных файлов отсутствует оператор;

#include <stdlib.h> // exposes function: `realpath()`

функция: e_getattr() также требуется `статический модификатор

...