diff options
author | Kevin O'Connor <kevin@koconnor.net> | 2010-12-31 14:38:10 -0500 |
---|---|---|
committer | Kevin O'Connor <kevin@koconnor.net> | 2011-01-01 11:01:19 -0500 |
commit | c2002a1be8e859f2f9022f7068f62977401798b4 (patch) | |
tree | d4cba32f8b45deaa8ef8de0ac04611aa6d379dc8 /src | |
parent | a5f2b91060ee43c9acd0162227b85153cbbae1c6 (diff) | |
download | seabios-c2002a1be8e859f2f9022f7068f62977401798b4.tar.gz |
Add support for finding the boot priority of USB drives.
Use the device path of the USB device to find a bootorder entry.
Diffstat (limited to 'src')
-rw-r--r-- | src/boot.c | 15 | ||||
-rw-r--r-- | src/boot.h | 3 | ||||
-rw-r--r-- | src/usb-msc.c | 10 |
3 files changed, 25 insertions, 3 deletions
@@ -162,6 +162,21 @@ int bootprio_find_named_rom(const char *name, int instance) return find_prio(desc); } +int bootprio_find_usb(int bdf, u64 path) +{ + // Find usb - for example: /pci@i0cf8/usb@1,2/hub@1/network@0/ethernet@0 + int i; + char desc[256], *p; + p = build_pci_path(desc, sizeof(desc), "usb", bdf); + for (i=56; i>0; i-=8) { + int port = (path >> i) & 0xff; + if (port != 0xff) + p += snprintf(p, desc+sizeof(desc)-p, "/hub@%x", port); + } + snprintf(p, desc+sizeof(desc)-p, "/*@%x", (u32)(path & 0xff)); + return find_prio(desc); +} + /**************************************************************** * Boot setup @@ -15,8 +15,9 @@ void boot_add_cbfs(void *data, const char *desc, int prio); void boot_prep(void); int bootprio_find_pci_device(int bdf); int bootprio_find_ata_device(int bdf, int chanid, int slave); -int bootprio_find_fdc_device(int bfd, int port, int fdid); +int bootprio_find_fdc_device(int bdf, int port, int fdid); int bootprio_find_pci_rom(int bdf, int instance); int bootprio_find_named_rom(const char *name, int instance); +int bootprio_find_usb(int bdf, u64 path); #endif // __BOOT_H diff --git a/src/usb-msc.c b/src/usb-msc.c index d5fe7bad..58a5d144 100644 --- a/src/usb-msc.c +++ b/src/usb-msc.c @@ -143,7 +143,10 @@ setup_drive_cdrom(struct disk_op_s *op, char *desc) { op->drive_g->blksize = CDROM_SECTOR_SIZE; op->drive_g->sectors = (u64)-1; - boot_add_cd(op->drive_g, desc, -1); + struct usb_pipe *pipe = container_of( + op->drive_g, struct usbdrive_s, drive)->bulkout; + int prio = bootprio_find_usb(pipe->cntl->bdf, pipe->path); + boot_add_cd(op->drive_g, desc, prio); return 0; } @@ -168,7 +171,10 @@ setup_drive_hd(struct disk_op_s *op, char *desc) dprintf(1, "USB MSC blksize=%d sectors=%d\n", blksize, sectors); // Register with bcv system. - boot_add_hd(op->drive_g, desc, -1); + struct usb_pipe *pipe = container_of( + op->drive_g, struct usbdrive_s, drive)->bulkout; + int prio = bootprio_find_usb(pipe->cntl->bdf, pipe->path); + boot_add_hd(op->drive_g, desc, prio); return 0; } |