Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/lib/libsa Rearrange the structures in the lfs bootbolloc...
details: https://anonhg.NetBSD.org/src/rev/6a035e9a5698
branches: trunk
changeset: 809618:6a035e9a5698
user: dholland <dholland%NetBSD.org@localhost>
date: Fri Jul 24 06:53:24 2015 +0000
description:
Rearrange the structures in the lfs bootbollocks slightly.
This generates the same output (at least on amd64) but will be more
robust until we're ready to deploy lfs64 bootblocks too.
XXX: I don't think these actually work right now, and the logic for
picking between v1 and v2 lfs formats (which is not related to ffsv1
vs. ffsv2) is definitely broken. But I haven't made it any worse.
diffstat:
sys/lib/libsa/lfsv1.c | 6 ++--
sys/lib/libsa/lfsv2.c | 6 ++--
sys/lib/libsa/ufs.c | 61 +++++++++++++++++++++++++++++++++++---------------
3 files changed, 48 insertions(+), 25 deletions(-)
diffs (204 lines):
diff -r 62b1a5e5c3b9 -r 6a035e9a5698 sys/lib/libsa/lfsv1.c
--- a/sys/lib/libsa/lfsv1.c Fri Jul 24 06:51:46 2015 +0000
+++ b/sys/lib/libsa/lfsv1.c Fri Jul 24 06:53:24 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lfsv1.c,v 1.9 2013/06/23 07:28:36 dholland Exp $ */
+/* $NetBSD: lfsv1.c,v 1.10 2015/07/24 06:53:24 dholland Exp $ */
#define LIBSA_LFS
#define REQUIRED_LFS_VERSION 1
@@ -15,12 +15,12 @@
#define ufs_dinode ulfs1_dinode
-#define fs_bsize lfs_ibsize
+#define fs_bsize dlfs_ibsize
#define IFILE_Vx IFILE_V1
#define INOPBx(fs) LFS_INOPB(fs)
-#define UFS_NINDIR LFS_NINDIR
+#define UFS_NINDIR(fs) ((fs)->dlfs_nindir)
#define ufs_blkoff(a, b) lfs_blkoff((a), (b))
#define ufs_lblkno(a, b) lfs_lblkno((a), (b))
#define dblksize(a, b, c) lfs_dblksize((a), (b), (c))
diff -r 62b1a5e5c3b9 -r 6a035e9a5698 sys/lib/libsa/lfsv2.c
--- a/sys/lib/libsa/lfsv2.c Fri Jul 24 06:51:46 2015 +0000
+++ b/sys/lib/libsa/lfsv2.c Fri Jul 24 06:53:24 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lfsv2.c,v 1.9 2013/06/23 07:28:36 dholland Exp $ */
+/* $NetBSD: lfsv2.c,v 1.10 2015/07/24 06:53:24 dholland Exp $ */
#define LIBSA_LFS
#define REQUIRED_LFS_VERSION 2
@@ -16,7 +16,7 @@
/* XXX wrong! but for now it won't build with ulfs2_dinode */
#define ufs_dinode ulfs1_dinode
-#define fs_bsize lfs_bsize
+#define fs_bsize dlfs_bsize
#define IFILE_Vx IFILE
#ifdef LFS_IFILE_FRAG_ADDRESSING /* XXX see sys/ufs/lfs/ -- not tested */
@@ -25,7 +25,7 @@
#define INOPBx(fs) LFS_INOPB(fs)
#endif
-#define UFS_NINDIR LFS_NINDIR
+#define UFS_NINDIR(fs) ((fs)->dlfs_nindir)
#define ufs_blkoff(a, b) lfs_blkoff((a), (b))
#define ufs_lblkno(a, b) lfs_lblkno((a), (b))
#define dblksize(a, b, c) lfs_dblksize((a), (b), (c))
diff -r 62b1a5e5c3b9 -r 6a035e9a5698 sys/lib/libsa/ufs.c
--- a/sys/lib/libsa/ufs.c Fri Jul 24 06:51:46 2015 +0000
+++ b/sys/lib/libsa/ufs.c Fri Jul 24 06:53:24 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ufs.c,v 1.65 2014/03/20 03:13:18 christos Exp $ */
+/* $NetBSD: ufs.c,v 1.66 2015/07/24 06:53:24 dholland Exp $ */
/*-
* Copyright (c) 1993
@@ -101,19 +101,42 @@
#ifdef LIBSA_LFS
/*
- * In-core LFS superblock. This exists only to placate the macros in lfs.h,
+ * In-core LFS superblock - just the on-disk one.
*/
-struct fs {
- struct dlfs lfs_dlfs;
-};
-#define fs_magic lfs_magic
-#define fs_maxsymlinklen lfs_maxsymlinklen
+typedef struct dlfs FS;
+#define fs_magic dlfs_magic
+#define fs_maxsymlinklen dlfs_maxsymlinklen
+
+/* XXX these will go away in the near future */
+#undef lfs_bmask
+#define lfs_bmask dlfs_bmask
+#undef lfs_ifile
+#define lfs_ifile dlfs_ifile
+#undef lfs_ifpb
+#define lfs_ifpb dlfs_ifpb
+#undef lfs_cleansz
+#define lfs_cleansz dlfs_cleansz
+#undef lfs_segtabsz
+#define lfs_segtabsz dlfs_segtabsz
+#undef lfs_idaddr
+#define lfs_idaddr dlfs_idaddr
+#undef lfs_inopb
+#define lfs_inopb dlfs_inopb
+#undef lfs_bshift
+#define lfs_bshift dlfs_bshift
+#undef lfs_bsize
+#define lfs_bsize dlfs_bsize
+#undef lfs_ffmask
+#define lfs_ffmask dlfs_ffmask
+#undef lfs_fsbtodb
+#define lfs_fsbtodb dlfs_fsbtodb
#define FS_MAGIC LFS_MAGIC
#define SBLOCKSIZE LFS_SBPAD
#define SBLOCKOFFSET LFS_LABELPAD
#else
-/* NB ufs2 doesn't use the common suberblock code... */
+/* NB ufs2 doesn't use the common superblock code... */
+typedef struct fs FS;
#define FS_MAGIC FS_UFS1_MAGIC
#define SBLOCKOFFSET SBLOCK_UFS1
#endif
@@ -167,7 +190,7 @@
*/
struct file {
off_t f_seekp; /* seek pointer */
- struct fs *f_fs; /* pointer to super-block */
+ FS *f_fs; /* pointer to super-block */
struct ufs_dinode f_di; /* copy of on-disk inode */
uint f_nishift; /* for blocks in indirect block */
indp_t f_ind_cache_block;
@@ -183,10 +206,10 @@
static int buf_read_file(struct open_file *, char **, size_t *);
static int search_directory(const char *, int, struct open_file *, ino32_t *);
#ifdef LIBSA_FFSv1
-static void ffs_oldfscompat(struct fs *);
+static void ffs_oldfscompat(FS *);
#endif
#ifdef LIBSA_FFSv2
-static int ffs_find_superblock(struct open_file *, struct fs *);
+static int ffs_find_superblock(struct open_file *, FS *);
#endif
@@ -198,7 +221,7 @@
find_inode_sector(ino32_t inumber, struct open_file *f, daddr_t *isp)
{
struct file *fp = (struct file *)f->f_fsdata;
- struct fs *fs = fp->f_fs;
+ FS *fs = fp->f_fs;
daddr_t ifileent_blkno;
char *ent_in_buf;
size_t buf_after_ent;
@@ -233,7 +256,7 @@
read_inode(ino32_t inumber, struct open_file *f)
{
struct file *fp = (struct file *)f->f_fsdata;
- struct fs *fs = fp->f_fs;
+ FS *fs = fp->f_fs;
char *buf;
size_t rsize;
int rc;
@@ -293,7 +316,7 @@
block_map(struct open_file *f, indp_t file_block, indp_t *disk_block_p)
{
struct file *fp = (struct file *)f->f_fsdata;
- struct fs *fs = fp->f_fs;
+ FS *fs = fp->f_fs;
uint level;
indp_t ind_cache;
indp_t ind_block_num;
@@ -395,7 +418,7 @@
buf_read_file(struct open_file *f, char **buf_p, size_t *size_p)
{
struct file *fp = (struct file *)f->f_fsdata;
- struct fs *fs = fp->f_fs;
+ FS *fs = fp->f_fs;
long off;
indp_t file_block;
size_t block_size;
@@ -499,7 +522,7 @@
daddr_t sblock_try[] = SBLOCKSEARCH;
static int
-ffs_find_superblock(struct open_file *f, struct fs *fs)
+ffs_find_superblock(struct open_file *f, FS *fs)
{
int i, rc;
size_t buf_size;
@@ -533,7 +556,7 @@
#endif
ino32_t inumber;
struct file *fp;
- struct fs *fs;
+ FS *fs;
int rc;
#ifndef LIBSA_NO_FS_SYMLINK
ino32_t parent_inumber;
@@ -587,7 +610,7 @@
#endif
if (fs->fs_bsize > MAXBSIZE ||
- (size_t)fs->fs_bsize < sizeof(struct fs)) {
+ (size_t)fs->fs_bsize < sizeof(FS)) {
rc = EINVAL;
goto out;
}
@@ -940,7 +963,7 @@
* Stripped of stuff libsa doesn't need.....
*/
static void
-ffs_oldfscompat(struct fs *fs)
+ffs_oldfscompat(FS *fs)
{
#ifdef COMPAT_UFS
Home |
Main Index |
Thread Index |
Old Index