long rc;
 
        mutex_lock(&df->lock);
-       if (df->unlocked_ioctl)
-               rc = df->unlocked_ioctl(file, cmd, arg);
-       else
-               rc = -ENOTTY;
+       rc = df->unlocked_ioctl(file, cmd, arg);
        mutex_unlock(&df->lock);
        return rc;
 }
 
-static const struct file_operations dbfs_ops = {
+static const struct file_operations dbfs_ops_ioctl = {
        .read           = dbfs_read,
        .unlocked_ioctl = dbfs_ioctl,
 };
 
+static const struct file_operations dbfs_ops = {
+       .read           = dbfs_read,
+};
+
 void hypfs_dbfs_create_file(struct hypfs_dbfs_file *df)
 {
-       df->dentry = debugfs_create_file(df->name, 0400, dbfs_dir, df,
-                                        &dbfs_ops);
+       const struct file_operations *fops = &dbfs_ops;
+
+       if (df->unlocked_ioctl)
+               fops = &dbfs_ops_ioctl;
+       df->dentry = debugfs_create_file(df->name, 0400, dbfs_dir, df, fops);
        mutex_init(&df->lock);
 }