extern void
iso9660_init_inode(struct v_superblock* vsb, struct v_inode* inode);
-uint32_t
+u32_t
iso9660_rd_capacity(struct v_superblock* vsb)
{
struct iso_superblock* isovsb = (struct iso_superblock*)vsb->data;
struct device* dev = vsb->dev;
struct iso_vol* vdesc = (struct iso_vol*)valloc(ISO9660_BLKSZ);
struct iso_vol_primary* vprim = NULL;
+ u32_t lba = 16;
int errno = 0;
do {
- errno = dev->read(dev, vdesc, ISO9660_BLKSZ * 16, ISO9660_BLKSZ);
+ errno = dev->ops.read(dev, vdesc, ISO9660_BLKSZ * lba, ISO9660_BLKSZ);
if (errno < 0) {
errno = EIO;
goto done;
vprim = (struct iso_vol_primary*)vdesc;
break;
}
-
+ lba++;
} while (vdesc->type != ISO_VOLTERM);
if (!vprim) {
vsb->ops.read_capacity = iso9660_rd_capacity;
struct v_inode* rootino = vfs_i_alloc(vsb);
- struct iso_drecord* dir =
- iso9660_get_drecord((struct iso_var_mdu*)vprim->root_record);
+ struct iso_var_mdu* mdu = (struct iso_var_mdu*)vprim->root_record;
+ struct iso_drecord* dir = iso9660_get_drecord(mdu);
if (!dir) {
vfree(isovsb);
}
struct iso_drecache drecache;
- iso9660_fill_drecache(&drecache, dir);
+ iso9660_fill_drecache(&drecache, dir, mdu->len);
if ((errno = iso9660_fill_inode(rootino, &drecache, 0)) < 0) {
vfree(isovsb);
}
vfs_i_addhash(rootino);
+ return 0;
done:
vfree(vdesc);
- return 0;
+ return errno;
}
int
iso9660_unmount(struct v_superblock* vsb)
{
- // TODO clean up
+ vfree(vsb->data);
+
+ return 0;
}
void