Вникаем в смысл кода простейшего примера файловой системы пространства пользователя - релизация с помощью 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
- 5554 reads