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: standard vga support (mode switching, framebuffer remapping)
[lunaix-os.git]
/
lunaix-os
/
kernel
/
block
/
block.c
diff --git
a/lunaix-os/kernel/block/block.c
b/lunaix-os/kernel/block/block.c
index 76ef7787f36d3864b162a96f3df7c4916d57bf1c..c78cd26a1e522b1679c760c0c69caa2eb0d204f9 100644
(file)
--- a/
lunaix-os/kernel/block/block.c
+++ b/
lunaix-os/kernel/block/block.c
@@
-318,16
+318,19
@@
__block_register(struct block_dev* bdev)
return 0;
}
return 0;
}
- struct device* dev =
- device_addvol(blk_parent_dev, bdev->class, bdev, "sd%c", 'a' + free_slot);
+ struct device* dev = device_allocvol(blk_parent_dev, bdev);
dev->ops.write = __block_write;
dev->ops.write_page = __block_write_page;
dev->ops.read = __block_read;
dev->ops.read_page = __block_read_page;
bdev->dev = dev;
dev->ops.write = __block_write;
dev->ops.write_page = __block_write_page;
dev->ops.read = __block_read;
dev->ops.read_page = __block_read_page;
bdev->dev = dev;
- strcpy(bdev->bdev_id, dev->name_val);
+
+ device_register(dev, bdev->class, "sd%c", 'a' + free_slot);
dev_registry[free_slot++] = bdev;
dev_registry[free_slot++] = bdev;
+
+ strcpy(bdev->bdev_id, dev->name_val);
+
return 1;
}
return 1;
}
@@
-341,8
+344,7
@@
blk_mount_part(struct block_dev* bdev,
struct block_dev* pbdev = cake_grab(lbd_pile);
memcpy(pbdev, bdev, sizeof(*bdev));
struct block_dev* pbdev = cake_grab(lbd_pile);
memcpy(pbdev, bdev, sizeof(*bdev));
- struct device* dev = device_addvol(
- NULL, pbdev->class, pbdev, "%sp%d", bdev->bdev_id, index + 1);
+ struct device* dev = device_allocvol(NULL, pbdev);
dev->ops.write = __block_write;
dev->ops.write_page = __block_write_page;
dev->ops.read = __block_read;
dev->ops.write = __block_write;
dev->ops.write_page = __block_write_page;
dev->ops.read = __block_read;
@@
-359,5
+361,7
@@
blk_mount_part(struct block_dev* bdev,
llist_append(&bdev->parts, &pbdev->parts);
llist_append(&bdev->parts, &pbdev->parts);
+ device_register(dev, pbdev->class, "%sp%d", bdev->bdev_id, index + 1);
+
return pbdev;
}
\ No newline at end of file
return pbdev;
}
\ No newline at end of file