summaryrefslogtreecommitdiff
path: root/ufs/hyper.c
diff options
context:
space:
mode:
Diffstat (limited to 'ufs/hyper.c')
-rw-r--r--ufs/hyper.c40
1 files changed, 21 insertions, 19 deletions
diff --git a/ufs/hyper.c b/ufs/hyper.c
index 052bc220..ece327a2 100644
--- a/ufs/hyper.c
+++ b/ufs/hyper.c
@@ -1,5 +1,5 @@
/* Fetching and storing the hypermetadata (superblock and cg summary info).
- Copyright (C) 1994, 1995, 1996 Free Software Foundation
+ Copyright (C) 1994, 95, 96, 97, 98, 1999 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
@@ -34,7 +34,7 @@ void
swab_sblock (struct fs *sblock)
{
int i, j;
-
+
sblock->fs_sblkno = swab_long (sblock->fs_sblkno);
sblock->fs_cblkno = swab_long (sblock->fs_cblkno);
sblock->fs_iblkno = swab_long (sblock->fs_iblkno);
@@ -108,24 +108,24 @@ swab_sblock (struct fs *sblock)
else
for (i = 0; i < sblock->fs_cpc; i++)
for (j = 0; j < sblock->fs_nrpos; j++)
- fs_postbl(sblock, j)[i]
+ fs_postbl(sblock, j)[i]
= swab_short (fs_postbl (sblock, j)[i]);
/* The rot table is all chars */
}
-
+
void
swab_csums (struct csum *csum)
{
int i;
-
+
for (i = 0; i < sblock->fs_ncg; i++)
{
csum[i].cs_ndir = swab_long (csum[i].cs_ndir);
csum[i].cs_nbfree = swab_long (csum[i].cs_nbfree);
csum[i].cs_nifree = swab_long (csum[i].cs_nifree);
csum[i].cs_nffree = swab_long (csum[i].cs_nffree);
- }
+ }
}
void
@@ -138,8 +138,7 @@ get_hypermetadata (void)
/* Free previous values. */
if (zeroblock)
- vm_deallocate (mach_task_self(),
- (vm_address_t)zeroblock, sblock->fs_bsize);
+ munmap ((caddr_t) zeroblock, sblock->fs_bsize);
if (csum)
free (csum);
@@ -252,14 +251,13 @@ get_hypermetadata (void)
if (store->size < sblock->fs_size * sblock->fs_fsize)
{
fprintf (stderr,
- "Disk size (%Zd) less than necessary "
+ "Disk size (%Ld) less than necessary "
"(superblock says we need %ld)\n",
store->size, sblock->fs_size * sblock->fs_fsize);
exit (1);
}
- vm_allocate (mach_task_self (),
- (vm_address_t *)&zeroblock, sblock->fs_bsize, 1);
+ zeroblock = mmap (0, sblock->fs_bsize, PROT_READ|PROT_WRITE, MAP_ANON, 0, 0);
/* If the filesystem has new features in it, don't pay attention to
the user's request not to use them. */
@@ -292,8 +290,10 @@ diskfs_set_hypermetadata (int wait, int clean)
size_t read = 0;
size_t bufsize = round_page (fragroundup (sblock, sblock->fs_cssize));
- err = store_read (store, fsbtodb (sblock, sblock->fs_csaddr), bufsize,
- &buf, &read);
+ err = store_read (store,
+ fsbtodb (sblock, sblock->fs_csaddr)
+ << log2_dev_blocks_per_dev_bsize,
+ bufsize, &buf, &read);
if (err)
return err;
else if (read != bufsize)
@@ -304,14 +304,16 @@ diskfs_set_hypermetadata (int wait, int clean)
bcopy (csum, buf, sblock->fs_cssize);
if (swab_disk)
swab_csums ((struct csum *)buf);
- err = store_write (store, fsbtodb (sblock, sblock->fs_csaddr),
+ err = store_write (store,
+ fsbtodb (sblock, sblock->fs_csaddr)
+ << log2_dev_blocks_per_dev_bsize,
buf, bufsize, &wrote);
if (!err && wrote != bufsize)
err = EIO;
}
- vm_deallocate (mach_task_self (), (vm_address_t)buf, read);
-
+ munmap (buf, read);
+
if (err)
{
spin_unlock (&alloclock);
@@ -392,9 +394,9 @@ copy_sblock ()
void
diskfs_readonly_changed (int readonly)
{
- vm_protect (mach_task_self (),
- (vm_address_t)disk_image, store->size,
- 0, VM_PROT_READ | (readonly ? 0 : VM_PROT_WRITE));
+ (*(readonly ? store_set_flags : store_clear_flags)) (store, STORE_READONLY);
+
+ mprotect (disk_image, store->size, PROT_READ | (readonly ? 0 : PROT_WRITE));
if (readonly)
{