Вникаем в смысл кода простейшего примера файловой системы пространства пользователя - релизация с помощью FUSE

Для справки - официальный сайт FUSE сайт

Итак, убедившись, что предложенный нам пример работает.
Попытаемся вникнуть в смысл кода файла с исходником test.c

Приведу его ещё раз , но теперь уже вместе с комментариями(по техническим причинам отбражения include-ы прописаны не совсем правильно)=

#include fuse.h> /* подлючаем определения базовых функций необходимых
 для создания файловой системы с помощью FUSE */
#include stdio.h> /* */
#include string.h> // содержит , помимо прочего, определения фукций си Ю работабющих со строками
#include errno.h> // определяет ошибки си
#include fcntl.h> // содержит определнения возможных вариантов состояния файлов
 
static const char *hello_str = "Hello World!\n";
static const char *hello_path = "/hello";
/* Далее мы определим действия функций, 
которые требуются для FUSE  при описании файловой системы*/ 

/*указатель на эту функцию будет передан модулю ядра FUSE в качестве 
поля getattr  структуры типа   fuse_operations  - эта функция определяет
метаинформацию о файле, путь к которому указан в переменной *path
метаиноформация возвращается в виде специальной структуры
 stat (читайте о ней ниже) 
*/
static int hello_getattr(const char *path, struct stat *stbuf)
{
    int res = 0;
 
    memset(stbuf, 0, sizeof(struct stat));
    if(strcmp(path, "/") == 0) {
        stbuf->st_mode = S_IFDIR | 0755;
        stbuf->st_nlink = 2;
    }
    else if(strcmp(path, hello_path) == 0) {
        stbuf->st_mode = S_IFREG | 0444;
        stbuf->st_nlink = 1;
        stbuf->st_size = strlen(hello_str);
    }
    else
        res = -ENOENT;
 
    return res;
}

/* указатель на эту функцию будет передан модулю ядра FUSE в качестве 
поля readdir структуры типа   fuse_operations  - эта функция определяет
порядок чтения данных из директории*/
static int hello_readdir(const char *path, void *buf, fuse_fill_dir_t filler,
                         off_t offset, struct fuse_file_info *fi)
{
    (void) offset;
    (void) fi;
 
    if(strcmp(path, "/") != 0)
        return -ENOENT;
 
    filler(buf, ".", NULL, 0);
    filler(buf, "..", NULL, 0);
    filler(buf, hello_path + 1, NULL, 0);
 
    return 0;
}
 
/* указатель на эту функцию будет передан модулю ядра FUSE в качестве 
поля open структуры типа   fuse_operations  - эта функция определяет
имеет ли право пользователь открыть файл /hello нашей файловой системы -
путём анализа данных структуры типа fuse_file_info (читайте о ней ниже)*/
static int hello_open(const char *path, struct fuse_file_info *fi)
{
    if(strcmp(path, hello_path) != 0)
        return -ENOENT;
 
    if((fi->flags & 3) != O_RDONLY)
        return -EACCES;
 
    return 0;
}
 
/* указатель на эту функцию будет передан модулю ядра FUSE в качестве 
поля  read структуры типа   fuse_operations  - эта функция определяет
как именно будет считываться информация из файла дял передачи пользователю*/
static int hello_read(const char *path, char *buf, size_t size, off_t offset,
                      struct fuse_file_info *fi)
{
    size_t len;
    (void) fi;
    if(strcmp(path, hello_path) != 0)
        return -ENOENT;
 
    len = strlen(hello_str);
    if (offset < len) {
        if (offset + size > len)
            size = len - offset;
        memcpy(buf, hello_str + offset, size);
    } else
        size = 0;
 
    return size;
}
 
static struct fuse_operations hello_oper;  /* в этой структуре FUSE  будут храниться ссылки на функций ,
 которые  реализуют операции ,определённые в рамках нашей файловой системы 
(порстранства пользователя) */
 
/* далее в главной функции нашей порграммы - точке входа - мы "соберём" 
структуру , определяющую операциидля нашей файловой системы
и передаим эту инофрмацию модулю FUSE*/
int main(int argc, char *argv[])
{
  // начало заполнения полей структуры
    hello_oper.getattr = hello_getattr;
    hello_oper.readdir = hello_readdir;
    hello_oper.open = hello_open;
    hello_oper.read = hello_read;
// окончание заполнения полей структуры
    return fuse_main(argc, argv, &hello_oper, 0); // передуём структуру с инф. об операциях модулю FUSE
}

Немного подробностей (о комментариях)=

  1. Структура stat FUSE
  2. Все функции для структуры fuse_operations стандартно определены как static - для обеспечения корректной работы функции fuse_main()
  3. О функции fuse_main() читайте здесь

Свой пример модификации и комментарии "внутренностей функций" этого кода я размещу здесь

.

_____________________________________________
Источники(читать подробнее)=
  1. Разработка собственной файловой системы с помощью FUSE
  2. официальный сайт FUSE сайт
  3. общий раздел инофрмации о FUSE = http://sourceforge.net/apps/mediawiki/fu...
  4. раздел базовых вопросов-ответов FUSE = http://sourceforge.net/apps/mediawiki/fu...
  5. Учебник , рассматривающий наш пример = http://sourceforge.net/apps/mediawiki/fu...
  6. Функция реалзующая open() использует структуру типа fuse_file_info
Ключевые слова и фразы(для поиска)=
написать файловую систему