Вникаем в смысл кода простейшего примера файловой системы пространства пользователя - релизация с помощью FUSE
Primary tabs
Forums:
Для справки - официальный сайт 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 }
Немного подробностей (о комментариях)=
- Структура stat FUSE
- Все функции для структуры fuse_operations стандартно определены как static - для обеспечения корректной работы функции fuse_main()
- О функции fuse_main() читайте здесь
Свой пример модификации и комментарии "внутренностей функций" этого кода я размещу здесь
.
_____________________________________________
Источники(читать подробнее)=
- Разработка собственной файловой системы с помощью FUSE
- официальный сайт FUSE сайт
- общий раздел инофрмации о FUSE = http://sourceforge.net/apps/mediawiki/fu...
- раздел базовых вопросов-ответов FUSE = http://sourceforge.net/apps/mediawiki/fu...
- Учебник , рассматривающий наш пример = http://sourceforge.net/apps/mediawiki/fu...
- Функция реалзующая open() использует структуру типа fuse_file_info
Ключевые слова и фразы(для поиска)=
написать файловую систему
- Log in to post comments
- 4766 reads