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: better rtc framework which aims to remove single rtc restrictions.
[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..19895609567b4647c1ea204e1ae21883b41465cd 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;
@@
-27,7
+27,7
@@
iso9660_mount(struct v_superblock* vsb, struct v_dnode* mount_point)
u32_t lba = 16;
int errno = 0;
do {
u32_t lba = 16;
int errno = 0;
do {
- errno = dev->read(dev, vdesc, ISO9660_BLKSZ * lba, ISO9660_BLKSZ);
+ errno = dev->
ops.
read(dev, vdesc, ISO9660_BLKSZ * lba, ISO9660_BLKSZ);
if (errno < 0) {
errno = EIO;
goto done;
if (errno < 0) {
errno = EIO;
goto done;
@@
-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,9
@@
done:
int
iso9660_unmount(struct v_superblock* vsb)
{
int
iso9660_unmount(struct v_superblock* vsb)
{
- // TODO clean up
+ vfree(vsb->data);
+
+ return 0;
}
void
}
void