Blame view
cmd/disk.c
3.06 KB
7405a1331
|
1 2 3 4 |
/* * (C) Copyright 2000-2011 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * |
1a4596601
|
5 |
* SPDX-License-Identifier: GPL-2.0+ |
7405a1331
|
6 7 8 |
*/ #include <common.h> #include <command.h> |
475c7970c
|
9 |
#include <part.h> |
7405a1331
|
10 11 12 13 |
int common_diskboot(cmd_tbl_t *cmdtp, const char *intf, int argc, char *const argv[]) { |
04681cb3a
|
14 15 |
__maybe_unused int dev; int part; |
475c7970c
|
16 17 |
ulong addr = CONFIG_SYS_LOAD_ADDR; ulong cnt; |
7405a1331
|
18 |
disk_partition_t info; |
21d29f7f9
|
19 |
#if defined(CONFIG_IMAGE_FORMAT_LEGACY) |
7405a1331
|
20 |
image_header_t *hdr; |
21d29f7f9
|
21 |
#endif |
4101f6879
|
22 |
struct blk_desc *dev_desc; |
7405a1331
|
23 |
|
73223f0e1
|
24 |
#if CONFIG_IS_ENABLED(FIT) |
7405a1331
|
25 26 27 28 |
const void *fit_hdr = NULL; #endif bootstage_mark(BOOTSTAGE_ID_IDE_START); |
475c7970c
|
29 |
if (argc > 3) { |
7405a1331
|
30 31 32 33 |
bootstage_error(BOOTSTAGE_ID_IDE_ADDR); return CMD_RET_USAGE; } bootstage_mark(BOOTSTAGE_ID_IDE_ADDR); |
475c7970c
|
34 35 |
if (argc > 1) addr = simple_strtoul(argv[1], NULL, 16); |
7405a1331
|
36 |
|
475c7970c
|
37 |
bootstage_mark(BOOTSTAGE_ID_IDE_BOOT_DEVICE); |
7405a1331
|
38 |
|
e35929e4a
|
39 |
part = blk_get_device_part_str(intf, (argc == 3) ? argv[2] : NULL, |
10a37fd7a
|
40 |
&dev_desc, &info, 1); |
475c7970c
|
41 |
if (part < 0) { |
7405a1331
|
42 43 44 |
bootstage_error(BOOTSTAGE_ID_IDE_TYPE); return 1; } |
7405a1331
|
45 |
|
bcce53d04
|
46 |
dev = dev_desc->devnum; |
475c7970c
|
47 |
bootstage_mark(BOOTSTAGE_ID_IDE_TYPE); |
7405a1331
|
48 |
|
475c7970c
|
49 50 51 52 53 |
printf(" Loading from %s device %d, partition %d: " "Name: %.32s Type: %.32s ", intf, dev, part, info.name, info.type); |
7405a1331
|
54 |
|
04735e9c5
|
55 56 57 |
debug("First Block: " LBAFU ", # of blocks: " LBAFU ", Block Size: %ld ", |
7405a1331
|
58 |
info.start, info.size, info.blksz); |
2a981dc2c
|
59 |
if (blk_dread(dev_desc, info.start, 1, (ulong *)addr) != 1) { |
7405a1331
|
60 61 62 63 64 65 66 67 |
printf("** Read error on %d:%d ", dev, part); bootstage_error(BOOTSTAGE_ID_IDE_PART_READ); return 1; } bootstage_mark(BOOTSTAGE_ID_IDE_PART_READ); switch (genimg_get_format((void *) addr)) { |
21d29f7f9
|
68 |
#if defined(CONFIG_IMAGE_FORMAT_LEGACY) |
7405a1331
|
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 |
case IMAGE_FORMAT_LEGACY: hdr = (image_header_t *) addr; bootstage_mark(BOOTSTAGE_ID_IDE_FORMAT); if (!image_check_hcrc(hdr)) { puts(" ** Bad Header Checksum ** "); bootstage_error(BOOTSTAGE_ID_IDE_CHECKSUM); return 1; } bootstage_mark(BOOTSTAGE_ID_IDE_CHECKSUM); image_print_contents(hdr); cnt = image_get_image_size(hdr); break; |
21d29f7f9
|
87 |
#endif |
73223f0e1
|
88 |
#if CONFIG_IS_ENABLED(FIT) |
7405a1331
|
89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 |
case IMAGE_FORMAT_FIT: fit_hdr = (const void *) addr; puts("Fit image detected... "); cnt = fit_get_size(fit_hdr); break; #endif default: bootstage_error(BOOTSTAGE_ID_IDE_FORMAT); puts("** Unknown image type "); return 1; } cnt += info.blksz - 1; cnt /= info.blksz; cnt -= 1; |
2a981dc2c
|
107 108 |
if (blk_dread(dev_desc, info.start + 1, cnt, (ulong *)(addr + info.blksz)) != cnt) { |
7405a1331
|
109 110 111 112 113 114 |
printf("** Read error on %d:%d ", dev, part); bootstage_error(BOOTSTAGE_ID_IDE_READ); return 1; } bootstage_mark(BOOTSTAGE_ID_IDE_READ); |
73223f0e1
|
115 |
#if CONFIG_IS_ENABLED(FIT) |
7405a1331
|
116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 |
/* This cannot be done earlier, * we need complete FIT image in RAM first */ if (genimg_get_format((void *) addr) == IMAGE_FORMAT_FIT) { if (!fit_check_format(fit_hdr)) { bootstage_error(BOOTSTAGE_ID_IDE_FIT_READ); puts("** Bad FIT image format "); return 1; } bootstage_mark(BOOTSTAGE_ID_IDE_FIT_READ_OK); fit_print_contents(fit_hdr); } #endif flush_cache(addr, (cnt+1)*info.blksz); /* Loading ok, update default load address */ load_addr = addr; return bootm_maybe_autostart(cmdtp, argv[0]); } |