diff options
author | Rafał Miłecki <zajec5@gmail.com> | 2013-12-21 13:39:11 -0500 |
---|---|---|
committer | Brian Norris <computersforpeace@gmail.com> | 2014-01-07 13:07:36 -0500 |
commit | 4f8aaf72287578c846ed7ac8c6114aacbf416e45 (patch) | |
tree | e68c6c996eb717cf220685324620e33439d7fa0e /drivers/mtd | |
parent | 7f11b4d411d0e1ac9217d8a0546f60e057540772 (diff) |
mtd: bcm47xxpart: find boot partition by CFE magic
Some devices have even nicer-to-recognize CFE thanks to the magic.
Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
Signed-off-by: Brian Norris <computersforpeace@gmail.com>
Diffstat (limited to 'drivers/mtd')
-rw-r--r-- | drivers/mtd/bcm47xxpart.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/mtd/bcm47xxpart.c b/drivers/mtd/bcm47xxpart.c index 931746ded989..877c17c7f5d3 100644 --- a/drivers/mtd/bcm47xxpart.c +++ b/drivers/mtd/bcm47xxpart.c | |||
@@ -23,10 +23,11 @@ | |||
23 | * Amount of bytes we read when analyzing each block of flash memory. | 23 | * Amount of bytes we read when analyzing each block of flash memory. |
24 | * Set it big enough to allow detecting partition and reading important data. | 24 | * Set it big enough to allow detecting partition and reading important data. |
25 | */ | 25 | */ |
26 | #define BCM47XXPART_BYTES_TO_READ 0x404 | 26 | #define BCM47XXPART_BYTES_TO_READ 0x4e8 |
27 | 27 | ||
28 | /* Magics */ | 28 | /* Magics */ |
29 | #define BOARD_DATA_MAGIC 0x5246504D /* MPFR */ | 29 | #define BOARD_DATA_MAGIC 0x5246504D /* MPFR */ |
30 | #define CFE_MAGIC 0x43464531 /* 1EFC */ | ||
30 | #define FACTORY_MAGIC 0x59544346 /* FCTY */ | 31 | #define FACTORY_MAGIC 0x59544346 /* FCTY */ |
31 | #define POT_MAGIC1 0x54544f50 /* POTT */ | 32 | #define POT_MAGIC1 0x54544f50 /* POTT */ |
32 | #define POT_MAGIC2 0x504f /* OP */ | 33 | #define POT_MAGIC2 0x504f /* OP */ |
@@ -102,8 +103,9 @@ static int bcm47xxpart_parse(struct mtd_info *master, | |||
102 | continue; | 103 | continue; |
103 | } | 104 | } |
104 | 105 | ||
105 | /* CFE has small NVRAM at 0x400 */ | 106 | /* Magic or small NVRAM at 0x400 */ |
106 | if (buf[0x400 / 4] == NVRAM_HEADER) { | 107 | if ((buf[0x4e0 / 4] == CFE_MAGIC && buf[0x4e4 / 4] == CFE_MAGIC) || |
108 | (buf[0x400 / 4] == NVRAM_HEADER)) { | ||
107 | bcm47xxpart_add_part(&parts[curr_part++], "boot", | 109 | bcm47xxpart_add_part(&parts[curr_part++], "boot", |
108 | offset, MTD_WRITEABLE); | 110 | offset, MTD_WRITEABLE); |
109 | continue; | 111 | continue; |