1affae2bfSwdenk /* 2affae2bfSwdenk * (C) Copyright 2001 3affae2bfSwdenk * Wolfgang Denk, DENX Software Engineering, wd@denx.de. 4affae2bfSwdenk * 5affae2bfSwdenk * See file CREDITS for list of people who contributed to this 6affae2bfSwdenk * project. 7affae2bfSwdenk * 8affae2bfSwdenk * This program is free software; you can redistribute it and/or 9affae2bfSwdenk * modify it under the terms of the GNU General Public License as 10affae2bfSwdenk * published by the Free Software Foundation; either version 2 of 11affae2bfSwdenk * the License, or (at your option) any later version. 12affae2bfSwdenk * 13affae2bfSwdenk * This program is distributed in the hope that it will be useful, 14affae2bfSwdenk * but WITHOUT ANY WARRANTY; without even the implied warranty of 15affae2bfSwdenk * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16affae2bfSwdenk * GNU General Public License for more details. 17affae2bfSwdenk * 18affae2bfSwdenk * You should have received a copy of the GNU General Public License 19affae2bfSwdenk * along with this program; if not, write to the Free Software 20affae2bfSwdenk * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 21affae2bfSwdenk * MA 02111-1307 USA 22affae2bfSwdenk */ 23affae2bfSwdenk 24affae2bfSwdenk #include <common.h> 25affae2bfSwdenk #include <command.h> 26affae2bfSwdenk #include <ide.h> 27735dd97bSGrant Likely #include <part.h> 28affae2bfSwdenk 29affae2bfSwdenk #undef PART_DEBUG 30affae2bfSwdenk 31affae2bfSwdenk #ifdef PART_DEBUG 32affae2bfSwdenk #define PRINTF(fmt,args...) printf (fmt ,##args) 33affae2bfSwdenk #else 34affae2bfSwdenk #define PRINTF(fmt,args...) 35affae2bfSwdenk #endif 36affae2bfSwdenk 37cde5c64dSJon Loeliger #if (defined(CONFIG_CMD_IDE) || \ 3875eb82ecSunsik Kim defined(CONFIG_CMD_MG_DISK) || \ 39c7057b52SDave Liu defined(CONFIG_CMD_SATA) || \ 40cde5c64dSJon Loeliger defined(CONFIG_CMD_SCSI) || \ 41cde5c64dSJon Loeliger defined(CONFIG_CMD_USB) || \ 421968e615Swdenk defined(CONFIG_MMC) || \ 431968e615Swdenk defined(CONFIG_SYSTEMACE) ) 44affae2bfSwdenk 45735dd97bSGrant Likely struct block_drvr { 46735dd97bSGrant Likely char *name; 47735dd97bSGrant Likely block_dev_desc_t* (*get_dev)(int dev); 48735dd97bSGrant Likely }; 49735dd97bSGrant Likely 50735dd97bSGrant Likely static const struct block_drvr block_drvr[] = { 51cde5c64dSJon Loeliger #if defined(CONFIG_CMD_IDE) 52735dd97bSGrant Likely { .name = "ide", .get_dev = ide_get_dev, }, 53735dd97bSGrant Likely #endif 54c7057b52SDave Liu #if defined(CONFIG_CMD_SATA) 55c7057b52SDave Liu {.name = "sata", .get_dev = sata_get_dev, }, 56c7057b52SDave Liu #endif 57cde5c64dSJon Loeliger #if defined(CONFIG_CMD_SCSI) 58735dd97bSGrant Likely { .name = "scsi", .get_dev = scsi_get_dev, }, 59735dd97bSGrant Likely #endif 60cde5c64dSJon Loeliger #if defined(CONFIG_CMD_USB) && defined(CONFIG_USB_STORAGE) 61735dd97bSGrant Likely { .name = "usb", .get_dev = usb_stor_get_dev, }, 62735dd97bSGrant Likely #endif 63735dd97bSGrant Likely #if defined(CONFIG_MMC) 64735dd97bSGrant Likely { .name = "mmc", .get_dev = mmc_get_dev, }, 65735dd97bSGrant Likely #endif 66735dd97bSGrant Likely #if defined(CONFIG_SYSTEMACE) 67735dd97bSGrant Likely { .name = "ace", .get_dev = systemace_get_dev, }, 68735dd97bSGrant Likely #endif 6975eb82ecSunsik Kim #if defined(CONFIG_CMD_MG_DISK) 7075eb82ecSunsik Kim { .name = "mgd", .get_dev = mg_disk_get_dev, }, 7175eb82ecSunsik Kim #endif 72735dd97bSGrant Likely { }, 73735dd97bSGrant Likely }; 74735dd97bSGrant Likely 75751bb571SStefan Roese DECLARE_GLOBAL_DATA_PTR; 76751bb571SStefan Roese 77735dd97bSGrant Likely block_dev_desc_t *get_dev(char* ifname, int dev) 78735dd97bSGrant Likely { 79735dd97bSGrant Likely const struct block_drvr *drvr = block_drvr; 80751bb571SStefan Roese block_dev_desc_t* (*reloc_get_dev)(int dev); 8123090dacSHeiko Schocher char *name; 82751bb571SStefan Roese 83*7e71dc68STim Kientzle if (!ifname) 84*7e71dc68STim Kientzle return NULL; 85*7e71dc68STim Kientzle 8623090dacSHeiko Schocher name = drvr->name; 872e5167ccSWolfgang Denk #ifdef CONFIG_NEEDS_MANUAL_RELOC 8823090dacSHeiko Schocher name += gd->reloc_off; 8923090dacSHeiko Schocher #endif 90b16aadf4SLei Wen while (drvr->name) { 9123090dacSHeiko Schocher name = drvr->name; 92521af04dSPeter Tyser reloc_get_dev = drvr->get_dev; 932e5167ccSWolfgang Denk #ifdef CONFIG_NEEDS_MANUAL_RELOC 9423090dacSHeiko Schocher name += gd->reloc_off; 95521af04dSPeter Tyser reloc_get_dev += gd->reloc_off; 96521af04dSPeter Tyser #endif 9723090dacSHeiko Schocher if (strncmp(ifname, name, strlen(name)) == 0) 98751bb571SStefan Roese return reloc_get_dev(dev); 99735dd97bSGrant Likely drvr++; 100735dd97bSGrant Likely } 101735dd97bSGrant Likely return NULL; 102735dd97bSGrant Likely } 103735dd97bSGrant Likely #else 104735dd97bSGrant Likely block_dev_desc_t *get_dev(char* ifname, int dev) 105735dd97bSGrant Likely { 106735dd97bSGrant Likely return NULL; 107735dd97bSGrant Likely } 108735dd97bSGrant Likely #endif 109735dd97bSGrant Likely 110cde5c64dSJon Loeliger #if (defined(CONFIG_CMD_IDE) || \ 11175eb82ecSunsik Kim defined(CONFIG_CMD_MG_DISK) || \ 112c7057b52SDave Liu defined(CONFIG_CMD_SATA) || \ 113cde5c64dSJon Loeliger defined(CONFIG_CMD_SCSI) || \ 114cde5c64dSJon Loeliger defined(CONFIG_CMD_USB) || \ 115735dd97bSGrant Likely defined(CONFIG_MMC) || \ 116735dd97bSGrant Likely defined(CONFIG_SYSTEMACE) ) 117735dd97bSGrant Likely 118affae2bfSwdenk /* ------------------------------------------------------------------------- */ 119affae2bfSwdenk /* 120affae2bfSwdenk * reports device info to the user 121affae2bfSwdenk */ 12269a2a4d9SSergei Trofimovich 12369a2a4d9SSergei Trofimovich #ifdef CONFIG_LBA48 12469a2a4d9SSergei Trofimovich typedef uint64_t lba512_t; 12569a2a4d9SSergei Trofimovich #else 12669a2a4d9SSergei Trofimovich typedef lbaint_t lba512_t; 12769a2a4d9SSergei Trofimovich #endif 12869a2a4d9SSergei Trofimovich 12969a2a4d9SSergei Trofimovich /* 13069a2a4d9SSergei Trofimovich * Overflowless variant of (block_count * mul_by / div_by) 13169a2a4d9SSergei Trofimovich * when div_by > mul_by 13269a2a4d9SSergei Trofimovich */ 13369a2a4d9SSergei Trofimovich static lba512_t lba512_muldiv (lba512_t block_count, lba512_t mul_by, lba512_t div_by) 13469a2a4d9SSergei Trofimovich { 13569a2a4d9SSergei Trofimovich lba512_t bc_quot, bc_rem; 13669a2a4d9SSergei Trofimovich 13769a2a4d9SSergei Trofimovich /* x * m / d == x / d * m + (x % d) * m / d */ 13869a2a4d9SSergei Trofimovich bc_quot = block_count / div_by; 13969a2a4d9SSergei Trofimovich bc_rem = block_count - div_by * bc_quot; 14069a2a4d9SSergei Trofimovich return bc_quot * mul_by + (bc_rem * mul_by) / div_by; 14169a2a4d9SSergei Trofimovich } 14269a2a4d9SSergei Trofimovich 143affae2bfSwdenk void dev_print (block_dev_desc_t *dev_desc) 144affae2bfSwdenk { 14569a2a4d9SSergei Trofimovich lba512_t lba512; /* number of blocks if 512bytes block size */ 146affae2bfSwdenk 147af75a45dSWolfgang Denk if (dev_desc->type == DEV_TYPE_UNKNOWN) { 148af75a45dSWolfgang Denk puts ("not available\n"); 149af75a45dSWolfgang Denk return; 150af75a45dSWolfgang Denk } 151af75a45dSWolfgang Denk 1528ec6e332STor Krill switch (dev_desc->if_type) { 153574b3195SDetlev Zundel case IF_TYPE_SCSI: 154574b3195SDetlev Zundel printf ("(%d:%d) Vendor: %s Prod.: %s Rev: %s\n", 155574b3195SDetlev Zundel dev_desc->target,dev_desc->lun, 156affae2bfSwdenk dev_desc->vendor, 157affae2bfSwdenk dev_desc->product, 158affae2bfSwdenk dev_desc->revision); 159574b3195SDetlev Zundel break; 1606e24a1ebSRemy Bohmer case IF_TYPE_ATAPI: 161574b3195SDetlev Zundel case IF_TYPE_IDE: 162574b3195SDetlev Zundel case IF_TYPE_SATA: 163574b3195SDetlev Zundel printf ("Model: %s Firm: %s Ser#: %s\n", 164574b3195SDetlev Zundel dev_desc->vendor, 165574b3195SDetlev Zundel dev_desc->revision, 166574b3195SDetlev Zundel dev_desc->product); 167574b3195SDetlev Zundel break; 1686e24a1ebSRemy Bohmer case IF_TYPE_SD: 1696e24a1ebSRemy Bohmer case IF_TYPE_MMC: 17047bebe34SNícolas Carneiro Lebedenco case IF_TYPE_USB: 17147bebe34SNícolas Carneiro Lebedenco printf ("Vendor: %s Rev: %s Prod: %s\n", 17247bebe34SNícolas Carneiro Lebedenco dev_desc->vendor, 17347bebe34SNícolas Carneiro Lebedenco dev_desc->revision, 17447bebe34SNícolas Carneiro Lebedenco dev_desc->product); 17547bebe34SNícolas Carneiro Lebedenco break; 1766e24a1ebSRemy Bohmer case IF_TYPE_DOC: 1776e24a1ebSRemy Bohmer puts("device type DOC\n"); 1786e24a1ebSRemy Bohmer return; 1798ec6e332STor Krill case IF_TYPE_UNKNOWN: 1806e24a1ebSRemy Bohmer puts("device type unknown\n"); 1816e24a1ebSRemy Bohmer return; 182574b3195SDetlev Zundel default: 1836e24a1ebSRemy Bohmer printf("Unhandled device type: %i\n", dev_desc->if_type); 184574b3195SDetlev Zundel return; 185affae2bfSwdenk } 186affae2bfSwdenk puts (" Type: "); 187affae2bfSwdenk if (dev_desc->removable) 188affae2bfSwdenk puts ("Removable "); 189affae2bfSwdenk switch (dev_desc->type & 0x1F) { 190726c0f1eSDetlev Zundel case DEV_TYPE_HARDDISK: 191726c0f1eSDetlev Zundel puts ("Hard Disk"); 192affae2bfSwdenk break; 193726c0f1eSDetlev Zundel case DEV_TYPE_CDROM: 194726c0f1eSDetlev Zundel puts ("CD ROM"); 195affae2bfSwdenk break; 196726c0f1eSDetlev Zundel case DEV_TYPE_OPDISK: 197726c0f1eSDetlev Zundel puts ("Optical Device"); 198affae2bfSwdenk break; 199726c0f1eSDetlev Zundel case DEV_TYPE_TAPE: 200726c0f1eSDetlev Zundel puts ("Tape"); 201affae2bfSwdenk break; 202726c0f1eSDetlev Zundel default: 203726c0f1eSDetlev Zundel printf ("# %02X #", dev_desc->type & 0x1F); 204affae2bfSwdenk break; 205affae2bfSwdenk } 206affae2bfSwdenk puts ("\n"); 207affae2bfSwdenk if ((dev_desc->lba * dev_desc->blksz)>0L) { 208affae2bfSwdenk ulong mb, mb_quot, mb_rem, gb, gb_quot, gb_rem; 209c40b2956Swdenk lbaint_t lba; 2106e592385Swdenk 211c40b2956Swdenk lba = dev_desc->lba; 212affae2bfSwdenk 213c40b2956Swdenk lba512 = (lba * (dev_desc->blksz/512)); 214affae2bfSwdenk /* round to 1 digit */ 21569a2a4d9SSergei Trofimovich mb = lba512_muldiv(lba512, 10, 2048); /* 2048 = (1024 * 1024) / 512 MB */ 21669a2a4d9SSergei Trofimovich 217affae2bfSwdenk mb_quot = mb / 10; 218affae2bfSwdenk mb_rem = mb - (10 * mb_quot); 219affae2bfSwdenk 220affae2bfSwdenk gb = mb / 1024; 221affae2bfSwdenk gb_quot = gb / 10; 222affae2bfSwdenk gb_rem = gb - (10 * gb_quot); 22342dfe7a1Swdenk #ifdef CONFIG_LBA48 2246e592385Swdenk if (dev_desc->lba48) 225c40b2956Swdenk printf (" Supports 48-bit addressing\n"); 226c40b2956Swdenk #endif 2274b142febSHeiko Schocher #if defined(CONFIG_SYS_64BIT_LBA) 2286c6166f5SMike Frysinger printf (" Capacity: %ld.%ld MB = %ld.%ld GB (%Ld x %ld)\n", 229c40b2956Swdenk mb_quot, mb_rem, 230c40b2956Swdenk gb_quot, gb_rem, 231c40b2956Swdenk lba, 232c40b2956Swdenk dev_desc->blksz); 233c40b2956Swdenk #else 234affae2bfSwdenk printf (" Capacity: %ld.%ld MB = %ld.%ld GB (%ld x %ld)\n", 235affae2bfSwdenk mb_quot, mb_rem, 236affae2bfSwdenk gb_quot, gb_rem, 237c40b2956Swdenk (ulong)lba, 238affae2bfSwdenk dev_desc->blksz); 239c40b2956Swdenk #endif 240affae2bfSwdenk } else { 241affae2bfSwdenk puts (" Capacity: not available\n"); 242affae2bfSwdenk } 243affae2bfSwdenk } 244b3aff0cbSJon Loeliger #endif 245affae2bfSwdenk 246cde5c64dSJon Loeliger #if (defined(CONFIG_CMD_IDE) || \ 24775eb82ecSunsik Kim defined(CONFIG_CMD_MG_DISK) || \ 248c7057b52SDave Liu defined(CONFIG_CMD_SATA) || \ 249cde5c64dSJon Loeliger defined(CONFIG_CMD_SCSI) || \ 250cde5c64dSJon Loeliger defined(CONFIG_CMD_USB) || \ 2517fac3f69SHaavard Skinnemoen defined(CONFIG_MMC) || \ 2523f85ce27Swdenk defined(CONFIG_SYSTEMACE) ) 253affae2bfSwdenk 254affae2bfSwdenk #if defined(CONFIG_MAC_PARTITION) || \ 255affae2bfSwdenk defined(CONFIG_DOS_PARTITION) || \ 256c7de829cSwdenk defined(CONFIG_ISO_PARTITION) || \ 25707f3d789Srichardretanubun defined(CONFIG_AMIGA_PARTITION) || \ 25807f3d789Srichardretanubun defined(CONFIG_EFI_PARTITION) 259affae2bfSwdenk 260affae2bfSwdenk void init_part (block_dev_desc_t * dev_desc) 261affae2bfSwdenk { 262affae2bfSwdenk #ifdef CONFIG_ISO_PARTITION 263affae2bfSwdenk if (test_part_iso(dev_desc) == 0) { 264affae2bfSwdenk dev_desc->part_type = PART_TYPE_ISO; 265affae2bfSwdenk return; 266affae2bfSwdenk } 267affae2bfSwdenk #endif 268affae2bfSwdenk 269affae2bfSwdenk #ifdef CONFIG_MAC_PARTITION 270affae2bfSwdenk if (test_part_mac(dev_desc) == 0) { 271affae2bfSwdenk dev_desc->part_type = PART_TYPE_MAC; 272affae2bfSwdenk return; 273affae2bfSwdenk } 274affae2bfSwdenk #endif 275affae2bfSwdenk 27607f3d789Srichardretanubun /* must be placed before DOS partition detection */ 27707f3d789Srichardretanubun #ifdef CONFIG_EFI_PARTITION 27807f3d789Srichardretanubun if (test_part_efi(dev_desc) == 0) { 27907f3d789Srichardretanubun dev_desc->part_type = PART_TYPE_EFI; 28007f3d789Srichardretanubun return; 28107f3d789Srichardretanubun } 28207f3d789Srichardretanubun #endif 28307f3d789Srichardretanubun 284affae2bfSwdenk #ifdef CONFIG_DOS_PARTITION 285affae2bfSwdenk if (test_part_dos(dev_desc) == 0) { 286affae2bfSwdenk dev_desc->part_type = PART_TYPE_DOS; 287affae2bfSwdenk return; 288affae2bfSwdenk } 289affae2bfSwdenk #endif 290c7de829cSwdenk 291c7de829cSwdenk #ifdef CONFIG_AMIGA_PARTITION 292c7de829cSwdenk if (test_part_amiga(dev_desc) == 0) { 293c7de829cSwdenk dev_desc->part_type = PART_TYPE_AMIGA; 294c7de829cSwdenk return; 295c7de829cSwdenk } 296c7de829cSwdenk #endif 297affae2bfSwdenk } 298affae2bfSwdenk 299affae2bfSwdenk 3003e3b9569SPeter Pearse int get_partition_info (block_dev_desc_t *dev_desc, int part 3013e3b9569SPeter Pearse , disk_partition_t *info) 302affae2bfSwdenk { 303affae2bfSwdenk switch (dev_desc->part_type) { 304affae2bfSwdenk #ifdef CONFIG_MAC_PARTITION 305affae2bfSwdenk case PART_TYPE_MAC: 306affae2bfSwdenk if (get_partition_info_mac(dev_desc,part,info) == 0) { 307affae2bfSwdenk PRINTF ("## Valid MAC partition found ##\n"); 308affae2bfSwdenk return (0); 309affae2bfSwdenk } 310affae2bfSwdenk break; 311affae2bfSwdenk #endif 312affae2bfSwdenk 313affae2bfSwdenk #ifdef CONFIG_DOS_PARTITION 314affae2bfSwdenk case PART_TYPE_DOS: 315affae2bfSwdenk if (get_partition_info_dos(dev_desc,part,info) == 0) { 316affae2bfSwdenk PRINTF ("## Valid DOS partition found ##\n"); 317affae2bfSwdenk return (0); 318affae2bfSwdenk } 319affae2bfSwdenk break; 320affae2bfSwdenk #endif 321affae2bfSwdenk 322affae2bfSwdenk #ifdef CONFIG_ISO_PARTITION 323affae2bfSwdenk case PART_TYPE_ISO: 324affae2bfSwdenk if (get_partition_info_iso(dev_desc,part,info) == 0) { 325affae2bfSwdenk PRINTF ("## Valid ISO boot partition found ##\n"); 326affae2bfSwdenk return (0); 327affae2bfSwdenk } 328affae2bfSwdenk break; 329affae2bfSwdenk #endif 330c7de829cSwdenk 331c7de829cSwdenk #ifdef CONFIG_AMIGA_PARTITION 332c7de829cSwdenk case PART_TYPE_AMIGA: 333c7de829cSwdenk if (get_partition_info_amiga(dev_desc, part, info) == 0) 334c7de829cSwdenk { 335c7de829cSwdenk PRINTF ("## Valid Amiga partition found ##\n"); 336c7de829cSwdenk return (0); 337c7de829cSwdenk } 338c7de829cSwdenk break; 339c7de829cSwdenk #endif 34007f3d789Srichardretanubun 34107f3d789Srichardretanubun #ifdef CONFIG_EFI_PARTITION 34207f3d789Srichardretanubun case PART_TYPE_EFI: 34307f3d789Srichardretanubun if (get_partition_info_efi(dev_desc,part,info) == 0) { 34407f3d789Srichardretanubun PRINTF ("## Valid EFI partition found ##\n"); 34507f3d789Srichardretanubun return (0); 34607f3d789Srichardretanubun } 34707f3d789Srichardretanubun break; 34807f3d789Srichardretanubun #endif 349affae2bfSwdenk default: 350affae2bfSwdenk break; 351affae2bfSwdenk } 352affae2bfSwdenk return (-1); 353affae2bfSwdenk } 354affae2bfSwdenk 355affae2bfSwdenk static void print_part_header (const char *type, block_dev_desc_t * dev_desc) 356affae2bfSwdenk { 357affae2bfSwdenk puts ("\nPartition Map for "); 358affae2bfSwdenk switch (dev_desc->if_type) { 359726c0f1eSDetlev Zundel case IF_TYPE_IDE: 360726c0f1eSDetlev Zundel puts ("IDE"); 361affae2bfSwdenk break; 362726c0f1eSDetlev Zundel case IF_TYPE_SATA: 363726c0f1eSDetlev Zundel puts ("SATA"); 364c7057b52SDave Liu break; 365726c0f1eSDetlev Zundel case IF_TYPE_SCSI: 366726c0f1eSDetlev Zundel puts ("SCSI"); 367affae2bfSwdenk break; 368726c0f1eSDetlev Zundel case IF_TYPE_ATAPI: 369726c0f1eSDetlev Zundel puts ("ATAPI"); 370affae2bfSwdenk break; 371726c0f1eSDetlev Zundel case IF_TYPE_USB: 372726c0f1eSDetlev Zundel puts ("USB"); 373affae2bfSwdenk break; 374726c0f1eSDetlev Zundel case IF_TYPE_DOC: 375726c0f1eSDetlev Zundel puts ("DOC"); 376affae2bfSwdenk break; 3778f3b9642SLei Wen case IF_TYPE_MMC: 3788f3b9642SLei Wen puts ("MMC"); 3798f3b9642SLei Wen break; 380726c0f1eSDetlev Zundel default: 381726c0f1eSDetlev Zundel puts ("UNKNOWN"); 382affae2bfSwdenk break; 383affae2bfSwdenk } 384affae2bfSwdenk printf (" device %d -- Partition Type: %s\n\n", 385affae2bfSwdenk dev_desc->dev, type); 386affae2bfSwdenk } 387affae2bfSwdenk 388affae2bfSwdenk void print_part (block_dev_desc_t * dev_desc) 389affae2bfSwdenk { 390affae2bfSwdenk 391affae2bfSwdenk switch (dev_desc->part_type) { 392affae2bfSwdenk #ifdef CONFIG_MAC_PARTITION 393affae2bfSwdenk case PART_TYPE_MAC: 394affae2bfSwdenk PRINTF ("## Testing for valid MAC partition ##\n"); 395affae2bfSwdenk print_part_header ("MAC", dev_desc); 396affae2bfSwdenk print_part_mac (dev_desc); 397affae2bfSwdenk return; 398affae2bfSwdenk #endif 399affae2bfSwdenk #ifdef CONFIG_DOS_PARTITION 400affae2bfSwdenk case PART_TYPE_DOS: 401affae2bfSwdenk PRINTF ("## Testing for valid DOS partition ##\n"); 402affae2bfSwdenk print_part_header ("DOS", dev_desc); 403affae2bfSwdenk print_part_dos (dev_desc); 404affae2bfSwdenk return; 405affae2bfSwdenk #endif 406affae2bfSwdenk 407affae2bfSwdenk #ifdef CONFIG_ISO_PARTITION 408affae2bfSwdenk case PART_TYPE_ISO: 409affae2bfSwdenk PRINTF ("## Testing for valid ISO Boot partition ##\n"); 410affae2bfSwdenk print_part_header ("ISO", dev_desc); 411affae2bfSwdenk print_part_iso (dev_desc); 412affae2bfSwdenk return; 413affae2bfSwdenk #endif 414c7de829cSwdenk 415c7de829cSwdenk #ifdef CONFIG_AMIGA_PARTITION 416c7de829cSwdenk case PART_TYPE_AMIGA: 417c7de829cSwdenk PRINTF ("## Testing for a valid Amiga partition ##\n"); 418c7de829cSwdenk print_part_header ("AMIGA", dev_desc); 419c7de829cSwdenk print_part_amiga (dev_desc); 420c7de829cSwdenk return; 421c7de829cSwdenk #endif 42207f3d789Srichardretanubun 42307f3d789Srichardretanubun #ifdef CONFIG_EFI_PARTITION 42407f3d789Srichardretanubun case PART_TYPE_EFI: 42507f3d789Srichardretanubun PRINTF ("## Testing for valid EFI partition ##\n"); 42607f3d789Srichardretanubun print_part_header ("EFI", dev_desc); 42707f3d789Srichardretanubun print_part_efi (dev_desc); 42807f3d789Srichardretanubun return; 42907f3d789Srichardretanubun #endif 430affae2bfSwdenk } 431affae2bfSwdenk puts ("## Unknown partition table\n"); 432affae2bfSwdenk } 433affae2bfSwdenk 434affae2bfSwdenk 43507f3d789Srichardretanubun #else /* neither MAC nor DOS nor ISO nor AMIGA nor EFI partition configured */ 4363e3b9569SPeter Pearse # error neither CONFIG_MAC_PARTITION nor CONFIG_DOS_PARTITION 43707f3d789Srichardretanubun # error nor CONFIG_ISO_PARTITION nor CONFIG_AMIGA_PARTITION 43807f3d789Srichardretanubun # error nor CONFIG_EFI_PARTITION configured! 439affae2bfSwdenk #endif 440affae2bfSwdenk 441cde5c64dSJon Loeliger #endif 442