X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/f6ab9c9ababa2cf6e5c723b83ffb9362094054e8..7b8a1bcad75628f9add4590db2bb9b8e418ee8eb:/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 4f38c6a..3cb4049 100644 --- a/lunaix-os/kernel/fs/probe_boot.c +++ b/lunaix-os/kernel/fs/probe_boot.c @@ -10,24 +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(KWARN "can not probe %x:%s (%d)\n", - pos->dev_id, - pos->name.value, - errno); - pos = NULL; + kprintf(KINFO "failed %xh:%xh, /dev/%s", + dev->ident.fn_grp, + dev->ident.unique, + dev->name.value); + dev = NULL; goto done; } @@ -36,9 +42,10 @@ probe_boot_medium() } if (*(u32_t*)volp->sys_id == LUNAIX_ID) { - kprintf(KINFO "[%x:%s] %s\n", - pos->dev_id, - 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; } @@ -46,5 +53,5 @@ probe_boot_medium() done: vfree(volp); - return pos; + return dev; } \ No newline at end of file