summaryrefslogtreecommitdiff
path: root/firmware/common/dircache.c
diff options
context:
space:
mode:
authorThomas Martitz <kugel@rockbox.org>2011-06-20 20:12:35 +0000
committerThomas Martitz <kugel@rockbox.org>2011-06-20 20:12:35 +0000
commit0b9c57d33e59a26b1f341632b990aff0dffd0fcb (patch)
treee19cf12186567cef7f6b564cb6488b0f2924cf7e /firmware/common/dircache.c
parent52abbb186d62f113eb468754332840d54bd7e756 (diff)
downloadrockbox-0b9c57d33e59a26b1f341632b990aff0dffd0fcb.tar.gz
rockbox-0b9c57d33e59a26b1f341632b990aff0dffd0fcb.zip
Dircache: Move struct maindata declaration to dircache.c and actually check for DIRCACHE_MAGIC when loading from disk.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@30037 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/common/dircache.c')
-rw-r--r--firmware/common/dircache.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/firmware/common/dircache.c b/firmware/common/dircache.c
index 56c408e02c..0f3c453ee7 100644
--- a/firmware/common/dircache.c
+++ b/firmware/common/dircache.c
@@ -503,6 +503,17 @@ static struct dircache_entry* dircache_get_entry(const char *path, bool go_down)
503} 503}
504 504
505#ifdef HAVE_EEPROM_SETTINGS 505#ifdef HAVE_EEPROM_SETTINGS
506
507#define DIRCACHE_MAGIC 0x00d0c0a1
508struct dircache_maindata {
509 long magic;
510 long size;
511 long entry_count;
512 long appflags;
513 struct dircache_entry *root_entry;
514 char *d_names_start;
515};
516
506/** 517/**
507 * Function to load the internal cache structure from disk to initialize 518 * Function to load the internal cache structure from disk to initialize
508 * the dircache really fast and little disk access. 519 * the dircache really fast and little disk access.
@@ -525,7 +536,7 @@ int dircache_load(void)
525 536
526 bytes_read = read(fd, &maindata, sizeof(struct dircache_maindata)); 537 bytes_read = read(fd, &maindata, sizeof(struct dircache_maindata));
527 if (bytes_read != sizeof(struct dircache_maindata) 538 if (bytes_read != sizeof(struct dircache_maindata)
528 || maindata.size <= 0) 539 || maindata.magic != DIRCACHE_MAGIC || maindata.size <= 0)
529 { 540 {
530 logf("Dircache file header error"); 541 logf("Dircache file header error");
531 close(fd); 542 close(fd);