X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/6f6da1abb22dff69dbb710bd2fd9d95f083f2b43..69777bdcab284335651a8002e2896f3862fa423d:/lunaix-os/kernel/fs/probe_boot.c diff --git a/lunaix-os/kernel/fs/probe_boot.c b/lunaix-os/kernel/fs/probe_boot.c index a935fc4..3cb4049 100644 --- a/lunaix-os/kernel/fs/probe_boot.c +++ b/lunaix-os/kernel/fs/probe_boot.c @@ -10,25 +10,30 @@ LOG_MODULE("PROBE") struct device* probe_boot_medium() { - struct device* block_cat = device_getbyname(NULL, "block", 5); + struct device_meta* block_cat = device_getbyname(NULL, "block", 5); if (!block_cat) { return NULL; } struct iso_vol_primary* volp = valloc(ISO9660_BLKSZ); - struct device *pos, *n; + struct device* dev = NULL; + struct device_meta *pos, *n; llist_for_each(pos, n, &block_cat->children, siblings) { + dev = resolve_device(pos); + if (!dev) { + continue; + } + int errno = - pos->ops.read(pos, (void*)volp, ISO9660_READ_OFF, ISO9660_BLKSZ); + dev->ops.read(dev, (void*)volp, ISO9660_READ_OFF, ISO9660_BLKSZ); if (errno < 0) { - kprintf(KINFO "failed %x:%d:%d, /dev/%s\n", - pos->class->meta, - pos->class->device, - pos->class->variant, - pos->name.value); - pos = NULL; + kprintf(KINFO "failed %xh:%xh, /dev/%s", + dev->ident.fn_grp, + dev->ident.unique, + dev->name.value); + dev = NULL; goto done; } @@ -37,11 +42,10 @@ probe_boot_medium() } if (*(u32_t*)volp->sys_id == LUNAIX_ID) { - kprintf(KINFO "%x:%d:%d, /dev/%s, %s\n", - pos->class->meta, - pos->class->device, - pos->class->variant, - pos->name.value, + kprintf(KINFO "%xh:%xh, /dev/%s, %s", + dev->ident.fn_grp, + dev->ident.unique, + dev->name.value, (char*)volp->vol_id); break; } @@ -49,5 +53,5 @@ probe_boot_medium() done: vfree(volp); - return pos; + return dev; } \ No newline at end of file