> да никак не различает - пишет ошибку, и всё... приходится на память
> запоминать
> mount -t ufs -o ro,ufstype=44bsd... иначе хрен на раздел попадёшь...
> и никакого rw. не работает в принципе...Тут пошла пьянка с исходниками пингвина, ими можно ответить на вопрос.
Файловая система регистрирует структуру file_system_type содержащую указатель .mount
на функцию, который в драйвере статически инициализирован. Эта функция вызывается
при монтировании fs-в системном вызове mount. В случае с ufs получается такая эстафета
static struct dentry *ufs_mount(struct file_system_type *fs_type,
int flags, const char *dev_name, void *data)
{
return mount_bdev(fs_type, flags, dev_name, data, ufs_fill_super);
}
в mount_bdev вызывается ufs_fill_super
static int ufs_fill_super(struct super_block *sb, void *data, int silent)
{
struct ufs_sb_info * sbi;
struct ufs_sb_private_info * uspi;
struct ufs_super_block_first * usb1;
struct ufs_super_block_second * usb2;
struct ufs_super_block_third * usb3;
struct ufs_buffer_head * ubh;
struct inode *inode;
unsigned block_size, super_block_size;
unsigned flags;
unsigned super_block_offset;
unsigned maxsymlen;
int ret = -EINVAL;
uspi = NULL;
ubh = NULL;
flags = 0;
UFSD("ENTER\n");
sbi = kzalloc(sizeof(struct ufs_sb_info), GFP_KERNEL);
if (!sbi)
goto failed_nomem;
sb->s_fs_info = sbi;
sbi->sb = sb;
UFSD("flag %u\n", (int)(sb->s_flags & MS_RDONLY));
#ifndef CONFIG_UFS_FS_WRITE
if (!(sb->s_flags & MS_RDONLY)) {
printk("ufs was compiled with read-only support, "
"can't be mounted as read-write\n");
goto failed;
}
#endif
mutex_init(&sbi->mutex);
mutex_init(&sbi->s_lock);....................................................
чёрным по белому.