Skip to content
Snippets Groups Projects
Commit e0b55325 authored by Ilya Yanok's avatar Ilya Yanok Committed by Wolfgang Denk
Browse files

jffs2: add sector_size field to part_info structure


This patch adds sector_size field to part_info structure (used
by new JFFS2 code).

Signed-off-by: default avatarIlya Yanok <yanok@emcraft.com>
parent f7384695
No related branches found
No related tags found
No related merge requests found
...@@ -339,11 +339,15 @@ static int part_validate_nor(struct mtdids *id, struct part_info *part) ...@@ -339,11 +339,15 @@ static int part_validate_nor(struct mtdids *id, struct part_info *part)
extern flash_info_t flash_info[]; extern flash_info_t flash_info[];
flash_info_t *flash; flash_info_t *flash;
int offset_aligned; int offset_aligned;
u32 end_offset; u32 end_offset, sector_size = 0;
int i; int i;
flash = &flash_info[id->num]; flash = &flash_info[id->num];
/* size of last sector */
part->sector_size = flash->size -
(flash->start[flash->sector_count-1] - flash->start[0]);
offset_aligned = 0; offset_aligned = 0;
for (i = 0; i < flash->sector_count; i++) { for (i = 0; i < flash->sector_count; i++) {
if ((flash->start[i] - flash->start[0]) == part->offset) { if ((flash->start[i] - flash->start[0]) == part->offset) {
...@@ -358,12 +362,18 @@ static int part_validate_nor(struct mtdids *id, struct part_info *part) ...@@ -358,12 +362,18 @@ static int part_validate_nor(struct mtdids *id, struct part_info *part)
} }
end_offset = part->offset + part->size; end_offset = part->offset + part->size;
offset_aligned = 0;
for (i = 0; i < flash->sector_count; i++) { for (i = 0; i < flash->sector_count; i++) {
if (i) {
sector_size = flash->start[i] - flash->start[i-1];
if (part->sector_size < sector_size)
part->sector_size = sector_size;
}
if ((flash->start[i] - flash->start[0]) == end_offset) if ((flash->start[i] - flash->start[0]) == end_offset)
return 0; offset_aligned = 1;
} }
if (flash->size == end_offset) if (offset_aligned || flash->size == end_offset)
return 0; return 0;
printf("%s%d: partition (%s) size alignment incorrect\n", printf("%s%d: partition (%s) size alignment incorrect\n",
...@@ -389,6 +399,8 @@ static int part_validate_nand(struct mtdids *id, struct part_info *part) ...@@ -389,6 +399,8 @@ static int part_validate_nand(struct mtdids *id, struct part_info *part)
nand = &nand_info[id->num]; nand = &nand_info[id->num];
part->sector_size = nand->erasesize;
if ((unsigned long)(part->offset) % nand->erasesize) { if ((unsigned long)(part->offset) % nand->erasesize) {
printf("%s%d: partition (%s) start offset alignment incorrect\n", printf("%s%d: partition (%s) start offset alignment incorrect\n",
MTD_DEV_TYPE(id->type), id->num, part->name); MTD_DEV_TYPE(id->type), id->num, part->name);
...@@ -424,6 +436,8 @@ static int part_validate_onenand(struct mtdids *id, struct part_info *part) ...@@ -424,6 +436,8 @@ static int part_validate_onenand(struct mtdids *id, struct part_info *part)
mtd = &onenand_mtd; mtd = &onenand_mtd;
part->sector_size = mtd->erasesize;
if ((unsigned long)(part->offset) % mtd->erasesize) { if ((unsigned long)(part->offset) % mtd->erasesize) {
printf("%s%d: partition (%s) start offset" printf("%s%d: partition (%s) start offset"
"alignment incorrect\n", "alignment incorrect\n",
......
...@@ -50,6 +50,7 @@ struct part_info { ...@@ -50,6 +50,7 @@ struct part_info {
u32 offset; /* offset within device */ u32 offset; /* offset within device */
void *jffs2_priv; /* used internaly by jffs2 */ void *jffs2_priv; /* used internaly by jffs2 */
u32 mask_flags; /* kernel MTD mask flags */ u32 mask_flags; /* kernel MTD mask flags */
u32 sector_size; /* size of sector */
struct mtd_device *dev; /* parent device */ struct mtd_device *dev; /* parent device */
}; };
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment