X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;ds=inline;f=lib%2Fpartmap.c;h=2b70f1d916f6e16e0235687f0f51007aac44f849;hb=08ec58075cd87236ea502c2c3b89e38126478167;hp=60ec168c41ae37f2b2604644c1fc3a95b3a2f3a7;hpb=a372c96ccaa1c49942947b6a13b2b915a4318f19;p=libucw.git diff --git a/lib/partmap.c b/lib/partmap.c index 60ec168c..2b70f1d9 100644 --- a/lib/partmap.c +++ b/lib/partmap.c @@ -1,7 +1,7 @@ /* * UCW Library -- Mapping of File Parts * - * (c) 2003 Martin Mares + * (c) 2003--2006 Martin Mares * (c) 2003--2005 Robert Spalek * * This software may be freely distributed and used according to the terms @@ -18,16 +18,19 @@ #include #include #include -#include +#ifdef CONFIG_PARTMAP_IS_MMAP +#define PARTMAP_WINDOW ~(size_t)0 +#else #ifdef TEST #define PARTMAP_WINDOW 4096 #else #define PARTMAP_WINDOW 16777216 #endif +#endif struct partmap * -partmap_open(byte *name, int writeable) +partmap_open(char *name, int writeable) { struct partmap *p = xmalloc_zero(sizeof(struct partmap)); @@ -37,6 +40,9 @@ partmap_open(byte *name, int writeable) if ((p->file_size = sh_seek(p->fd, 0, SEEK_END)) < 0) die("lseek(%s): %m", name); p->writeable = writeable; +#ifdef CONFIG_PARTMAP_IS_MMAP + partmap_load(p, 0, p->file_size); +#endif return p; } @@ -61,17 +67,18 @@ partmap_load(struct partmap *p, sh_off_t start, uns size) if (p->start_map) munmap(p->start_map, p->end_off - p->start_off); sh_off_t end = start + size; - sh_off_t win_start = start/PAGE_SIZE * PAGE_SIZE; - uns win_len = PARTMAP_WINDOW; + sh_off_t win_start = start/CPU_PAGE_SIZE * CPU_PAGE_SIZE; + size_t win_len = PARTMAP_WINDOW; if ((sh_off_t) (win_start+win_len) > p->file_size) - win_len = ALIGN(p->file_size - win_start, PAGE_SIZE); + win_len = ALIGN_TO(p->file_size - win_start, CPU_PAGE_SIZE); if ((sh_off_t) (win_start+win_len) < end) die("partmap_map: Window is too small for mapping %d bytes", size); p->start_map = sh_mmap(NULL, win_len, p->writeable ? (PROT_READ | PROT_WRITE) : PROT_READ, MAP_SHARED, p->fd, win_start); if (p->start_map == MAP_FAILED) - die("mmap failed at position %Ld: %m", (long long)win_start); + die("mmap failed at position %lld: %m", (long long)win_start); p->start_off = win_start; p->end_off = win_start+win_len; + madvise(p->start_map, win_len, MADV_SEQUENTIAL); } #ifdef TEST