git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
feat: (iso9660) finishing up unmount
[lunaix-os.git]
/
lunaix-os
/
kernel
/
fs
/
iso9660
/
mount.c
diff --git
a/lunaix-os/kernel/fs/iso9660/mount.c
b/lunaix-os/kernel/fs/iso9660/mount.c
index 5d7bb819735d4df7e255df774bba58c3960386ea..35ebb4b3d53bc8219e909f27bee4f82e37fda265 100644
(file)
--- a/
lunaix-os/kernel/fs/iso9660/mount.c
+++ b/
lunaix-os/kernel/fs/iso9660/mount.c
@@
-11,7
+11,7
@@
struct cake_pile* drec_cache_pile;
extern void
iso9660_init_inode(struct v_superblock* vsb, struct v_inode* inode);
extern void
iso9660_init_inode(struct v_superblock* vsb, struct v_inode* inode);
-u
int
32_t
+u32_t
iso9660_rd_capacity(struct v_superblock* vsb)
{
struct iso_superblock* isovsb = (struct iso_superblock*)vsb->data;
iso9660_rd_capacity(struct v_superblock* vsb)
{
struct iso_superblock* isovsb = (struct iso_superblock*)vsb->data;
@@
-57,8
+57,8
@@
iso9660_mount(struct v_superblock* vsb, struct v_dnode* mount_point)
vsb->ops.read_capacity = iso9660_rd_capacity;
struct v_inode* rootino = vfs_i_alloc(vsb);
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);
if (!dir) {
vfree(isovsb);
@@
-67,7
+67,7
@@
iso9660_mount(struct v_superblock* vsb, struct v_dnode* mount_point)
}
struct iso_drecache drecache;
}
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);
if ((errno = iso9660_fill_inode(rootino, &drecache, 0)) < 0) {
vfree(isovsb);
@@
-92,7
+92,7
@@
done:
int
iso9660_unmount(struct v_superblock* vsb)
{
int
iso9660_unmount(struct v_superblock* vsb)
{
- // TODO clean up
+ vfree(vsb->data);
}
void
}
void