Module Name:    src
Committed By:   dholland
Date:           Tue Jul 28 05:14:23 UTC 2015

Modified Files:
        src/libexec/lfs_cleanerd: cleaner.h coalesce.c lfs_cleanerd.c
        src/sys/ufs/lfs: lfs_accessors.h

Log Message:
Use lfs_accessors.h in conjunction with the cleaner's struct clfs.
Remove previous hacks.


To generate a diff of this commit:
cvs rdiff -u -r1.8 -r1.9 src/libexec/lfs_cleanerd/cleaner.h
cvs rdiff -u -r1.27 -r1.28 src/libexec/lfs_cleanerd/coalesce.c
cvs rdiff -u -r1.40 -r1.41 src/libexec/lfs_cleanerd/lfs_cleanerd.c
cvs rdiff -u -r1.1 -r1.2 src/sys/ufs/lfs/lfs_accessors.h

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/libexec/lfs_cleanerd/cleaner.h
diff -u src/libexec/lfs_cleanerd/cleaner.h:1.8 src/libexec/lfs_cleanerd/cleaner.h:1.9
--- src/libexec/lfs_cleanerd/cleaner.h:1.8	Tue Jul 28 05:09:34 2015
+++ src/libexec/lfs_cleanerd/cleaner.h	Tue Jul 28 05:14:23 2015
@@ -37,91 +37,12 @@ struct clfs {
 	int clfs_onhold;	   /* If cleaning this fs is on hold */
 };
 
-// XXX temporary
-#include <ufs/lfs/lfs_accessors.h>
-
-/* ugh... */
-#define CLFS_DEF_SB_ACCESSOR(type, field) \
-	static __unused inline type				\
-	clfs_sb_get##field(struct clfs *fs)			\
-	{							\
-		return fs->lfs_dlfs.dlfs_##field;		\
-	}							\
-	static __unused inline void				\
-	clfs_sb_set##field(struct clfs *fs, type val)		\
-	{							\
-		fs->lfs_dlfs.dlfs_##field = val;		\
-	}							\
-	static __unused inline void				\
-	clfs_sb_add##field(struct clfs *fs, type val)		\
-	{							\
-		type *p = &fs->lfs_dlfs.dlfs_##field;		\
-		*p += val;					\
-	}
-
-/* more ugh... */
-CLFS_DEF_SB_ACCESSOR(u_int32_t, ssize);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, bsize);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, fsize);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, frag);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, ifile);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, inopb);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, ifpb);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, sepb);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, nseg);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, cleansz);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, segtabsz);
-CLFS_DEF_SB_ACCESSOR(u_int64_t, bmask);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, bshift);
-CLFS_DEF_SB_ACCESSOR(u_int64_t, ffmask);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, ffshift);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, fbshift);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, blktodb);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, minfreeseg);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, sumsize);
-CLFS_DEF_SB_ACCESSOR(u_int32_t, ibsize);
-CLFS_DEF_SB_ACCESSOR(int32_t, s0addr);
-static __unused inline int32_t
-clfs_sb_getsboff(struct clfs *fs, unsigned n)
-{
-	assert(n < LFS_MAXNUMSB);
-	return fs->lfs_dlfs.dlfs_sboffs[n];
-}
-static __unused inline const char *
-clfs_sb_getfsmnt(struct clfs *fs)
-{
-	return (const char *)fs->lfs_dlfs.dlfs_fsmnt;
-}
-
-/* still more ugh... */
-#define lfs_sb_getssize(fs) clfs_sb_getssize(fs)
-#define lfs_sb_getbsize(fs) clfs_sb_getbsize(fs)
-#define lfs_sb_getfsize(fs) clfs_sb_getfsize(fs)
-#define lfs_sb_getfrag(fs) clfs_sb_getfrag(fs)
-#define lfs_sb_getinopb(fs) clfs_sb_getinopb(fs)
-#define lfs_sb_getifpb(fs) clfs_sb_getifpb(fs)
-#define lfs_sb_getsepb(fs) clfs_sb_getsepb(fs)
-#define lfs_sb_getnseg(fs) clfs_sb_getnseg(fs)
-#define lfs_sb_getcleansz(fs) clfs_sb_getcleansz(fs)
-#define lfs_sb_getsegtabsz(fs) clfs_sb_getsegtabsz(fs)
-#define lfs_sb_getbmask(fs) clfs_sb_getbmask(fs)
-#define lfs_sb_getbshift(fs) clfs_sb_getbshift(fs)
-#define lfs_sb_getffmask(fs) clfs_sb_getffmask(fs)
-#define lfs_sb_getffshift(fs) clfs_sb_getffshift(fs)
-#define lfs_sb_getfbshift(fs) clfs_sb_getfbshift(fs)
-#define lfs_sb_getblktodb(fs) clfs_sb_getblktodb(fs)
-#define lfs_sb_getminfreeseg(fs) clfs_sb_getminfreeseg(fs)
-#define lfs_sb_getsumsize(fs) clfs_sb_getsumsize(fs)
-#define lfs_sb_getibsize(fs) clfs_sb_getibsize(fs)
-#define lfs_sb_gets0addr(fs) clfs_sb_gets0addr(fs)
-#define lfs_sb_getsboff(fs, n) clfs_sb_getsboff(fs, n)
-#define lfs_sb_getfsmnt(fs) clfs_sb_getfsmnt(fs)
-
 /*
- * This needs to come after the definition of struct clfs. (XXX blah)
+ * Get lfs accessors that use struct clfs. This must come after the
+ * definition of struct clfs. (blah)
  */
-//#define STRUCT_LFS struct clfs
-//#include <ufs/lfs/lfs_accessors.h>
+#define STRUCT_LFS struct clfs
+#include <ufs/lfs/lfs_accessors.h>
 
 /*
  * Fraction of the could-be-clean segments required to be clean.

Index: src/libexec/lfs_cleanerd/coalesce.c
diff -u src/libexec/lfs_cleanerd/coalesce.c:1.27 src/libexec/lfs_cleanerd/coalesce.c:1.28
--- src/libexec/lfs_cleanerd/coalesce.c:1.27	Tue Jul 28 05:09:34 2015
+++ src/libexec/lfs_cleanerd/coalesce.c	Tue Jul 28 05:14:23 2015
@@ -1,4 +1,4 @@
-/*      $NetBSD: coalesce.c,v 1.27 2015/07/28 05:09:34 dholland Exp $  */
+/*      $NetBSD: coalesce.c,v 1.28 2015/07/28 05:14:23 dholland Exp $  */
 
 /*-
  * Copyright (c) 2002, 2005 The NetBSD Foundation, Inc.
@@ -38,7 +38,6 @@
 #include <sys/mman.h>
 
 #include <ufs/lfs/lfs.h>
-#include <ufs/lfs/lfs_accessors.h>
 
 #include <fcntl.h>
 #include <signal.h>
@@ -217,10 +216,10 @@ clean_inode(struct clfs *fs, ino_t ino)
 #endif
 	noff = toff = 0;
 	for (i = 1; i < nb; i++) {
-		if (bip[i].bi_daddr != bip[i - 1].bi_daddr + clfs_sb_getfrag(fs))
+		if (bip[i].bi_daddr != bip[i - 1].bi_daddr + lfs_sb_getfrag(fs))
 			++noff;
 		toff += abs(bip[i].bi_daddr - bip[i - 1].bi_daddr
-		    - clfs_sb_getfrag(fs)) >> lfs_sb_getfbshift(fs);
+		    - lfs_sb_getfrag(fs)) >> lfs_sb_getfbshift(fs);
 	}
 
 	/*
@@ -299,7 +298,7 @@ clean_inode(struct clfs *fs, ino_t ino)
 	bps = lfs_segtod(fs, 1);
 	for (tbip = bip; tbip < bip + nb; tbip += bps) {
 		do {
-			bread(fs->lfs_ivnode, 0, clfs_sb_getbsize(fs), 0, &bp);
+			bread(fs->lfs_ivnode, 0, lfs_sb_getbsize(fs), 0, &bp);
 			cip = *(CLEANERINFO *)bp->b_data;
 			brelse(bp, B_INVAL);
 

Index: src/libexec/lfs_cleanerd/lfs_cleanerd.c
diff -u src/libexec/lfs_cleanerd/lfs_cleanerd.c:1.40 src/libexec/lfs_cleanerd/lfs_cleanerd.c:1.41
--- src/libexec/lfs_cleanerd/lfs_cleanerd.c:1.40	Fri Jul 24 06:59:31 2015
+++ src/libexec/lfs_cleanerd/lfs_cleanerd.c	Tue Jul 28 05:14:23 2015
@@ -1,4 +1,4 @@
-/* $NetBSD: lfs_cleanerd.c,v 1.40 2015/07/24 06:59:31 dholland Exp $	 */
+/* $NetBSD: lfs_cleanerd.c,v 1.41 2015/07/28 05:14:23 dholland Exp $	 */
 
 /*-
  * Copyright (c) 2005 The NetBSD Foundation, Inc.
@@ -269,8 +269,8 @@ init_fs(struct clfs *fs, char *fsname)
 	memcpy(fs->lfs_dlfs.dlfs_fsmnt, mnttmp, sizeof(mnttmp));
 
 	/* Set up vnodes for Ifile and raw device */
-	fs->lfs_ivnode = fd_vget(fs->clfs_ifilefd, clfs_sb_getbsize(fs), 0, 0);
-	fs->clfs_devvp = fd_vget(fs->clfs_devfd, clfs_sb_getfsize(fs), clfs_sb_getssize(fs),
+	fs->lfs_ivnode = fd_vget(fs->clfs_ifilefd, lfs_sb_getbsize(fs), 0, 0);
+	fs->clfs_devvp = fd_vget(fs->clfs_devfd, lfs_sb_getfsize(fs), lfs_sb_getssize(fs),
 				 atatime);
 
 	/* Allocate and clear segtab */
@@ -317,9 +317,9 @@ reload_ifile(struct clfs *fs)
 
 	/* If Ifile is larger than buffer cache, rehash */
 	fstat(fs->clfs_ifilefd, &st);
-	if (st.st_size / clfs_sb_getbsize(fs) > hashmax) {
+	if (st.st_size / lfs_sb_getbsize(fs) > hashmax) {
 		ohashmax = hashmax;
-		bufrehash(st.st_size / clfs_sb_getbsize(fs));
+		bufrehash(st.st_size / lfs_sb_getbsize(fs));
 		dlog("%s: resized buffer hash from %d to %d",
 		     lfs_sb_getfsmnt(fs), ohashmax, hashmax);
 	}
@@ -337,7 +337,7 @@ lfs_ientry(IFILE **ifpp, struct clfs *fs
 
 	error = bread(fs->lfs_ivnode,
 		      ino / lfs_sb_getifpb(fs) + lfs_sb_getcleansz(fs) +
-		      lfs_sb_getsegtabsz(fs), clfs_sb_getbsize(fs), 0, bpp);
+		      lfs_sb_getsegtabsz(fs), lfs_sb_getbsize(fs), 0, bpp);
 	if (error)
 		syslog(LOG_ERR, "%s: ientry failed for ino %d",
 			lfs_sb_getfsmnt(fs), (int)ino);
@@ -519,7 +519,7 @@ parse_pseg(struct clfs *fs, daddr_t dadd
 
 			syslog(LOG_WARNING, "fixing short FINFO at %x (seg %d)",
 			       odaddr, lfs_dtosn(fs, odaddr));
-			bread(fs->clfs_devvp, odaddr, clfs_sb_getfsize(fs),
+			bread(fs->clfs_devvp, odaddr, lfs_sb_getfsize(fs),
 			    0, &nbp);
 			nssp = (SEGSUM *)nbp->b_data;
 			--nssp->ss_nfinfo;
@@ -548,7 +548,7 @@ parse_pseg(struct clfs *fs, daddr_t dadd
 			/* Read all the blocks from the data summary */
 			for (i = 0; i < fip->fi_nblocks; i++) {
 				size = (i == fip->fi_nblocks - 1) ?
-					fip->fi_lastlength : clfs_sb_getbsize(fs);
+					fip->fi_lastlength : lfs_sb_getbsize(fs);
 				cp = fd_ptrget(fs->clfs_devvp, daddr);
 				ck = lfs_cksum_part(cp, sizeof(u_int32_t), ck);
 				daddr += lfs_btofsb(fs, size);
@@ -574,7 +574,7 @@ parse_pseg(struct clfs *fs, daddr_t dadd
 			bip[*bic + i].bi_segcreate = ssp->ss_create;
 			bip[*bic + i].bi_version = fip->fi_version;
 			bip[*bic + i].bi_size = (i == fip->fi_nblocks - 1) ?
-				fip->fi_lastlength : clfs_sb_getbsize(fs);
+				fip->fi_lastlength : lfs_sb_getbsize(fs);
 			cp = fd_ptrget(fs->clfs_devvp, daddr);
 			ck = lfs_cksum_part(cp, sizeof(u_int32_t), ck);
 			bip[*bic + i].bi_bp = cp;
@@ -623,7 +623,7 @@ log_segment_read(struct clfs *fs, int sn
 
         fp = fopen(copylog_filename, "ab");
         if (fp != NULL) {
-                if (fwrite(cp, (size_t)clfs_sb_getssize(fs), 1, fp) != 1) {
+                if (fwrite(cp, (size_t)lfs_sb_getssize(fs), 1, fp) != 1) {
                         perror("writing segment to copy log");
                 }
         }
@@ -659,12 +659,12 @@ load_segment(struct clfs *fs, int sn, BL
 
 	/* Note bytes read for stats */
 	cleaner_stats.segs_cleaned++;
-	cleaner_stats.bytes_read += clfs_sb_getssize(fs);
+	cleaner_stats.bytes_read += lfs_sb_getssize(fs);
 	++fs->clfs_nactive;
 
 	npseg = 0;
 	while(lfs_dtosn(fs, daddr) == sn &&
-	      lfs_dtosn(fs, daddr + lfs_btofsb(fs, clfs_sb_getbsize(fs))) == sn) {
+	      lfs_dtosn(fs, daddr + lfs_btofsb(fs, lfs_sb_getbsize(fs))) == sn) {
 		daddr = parse_pseg(fs, daddr, bipp, bic);
 		if (daddr == 0x0) {
 			++cleaner_stats.segs_error;
@@ -708,7 +708,7 @@ calc_cb(struct clfs *fs, int sn, struct 
 		return;
 	}
 
-	if (t->nbytes > clfs_sb_getssize(fs)) {
+	if (t->nbytes > lfs_sb_getssize(fs)) {
 		/* Another type of error */
 		syslog(LOG_WARNING, "segment %d: bad seguse count %d",
 		       sn, t->nbytes);
@@ -725,16 +725,16 @@ calc_cb(struct clfs *fs, int sn, struct 
 	 * We count the summary headers as "dirty" to avoid cleaning very
 	 * old and very full segments.
 	 */
-	benefit = (int64_t)clfs_sb_getssize(fs) - t->nbytes -
-		  (t->nsums + 1) * clfs_sb_getfsize(fs);
-	if (clfs_sb_getbsize(fs) > clfs_sb_getfsize(fs)) /* fragmentation */
-		benefit -= (clfs_sb_getbsize(fs) / 2);
+	benefit = (int64_t)lfs_sb_getssize(fs) - t->nbytes -
+		  (t->nsums + 1) * lfs_sb_getfsize(fs);
+	if (lfs_sb_getbsize(fs) > lfs_sb_getfsize(fs)) /* fragmentation */
+		benefit -= (lfs_sb_getbsize(fs) / 2);
 	if (benefit <= 0) {
 		t->priority = 0;
 		return;
 	}
 
-	cost = clfs_sb_getssize(fs) + t->nbytes;
+	cost = lfs_sb_getssize(fs) + t->nbytes;
 	t->priority = (256 * benefit * age) / cost;
 
 	return;
@@ -873,7 +873,7 @@ invalidate_segment(struct clfs *fs, int 
 	/* Record statistics */
 	for (i = nb = 0; i < bic; i++)
 		nb += bip[i].bi_size;
-	util = ((double)nb) / (fs->clfs_nactive * clfs_sb_getssize(fs));
+	util = ((double)nb) / (fs->clfs_nactive * lfs_sb_getssize(fs));
 	cleaner_stats.util_tot += util;
 	cleaner_stats.util_sos += util * util;
 	cleaner_stats.bytes_written += nb;
@@ -970,10 +970,10 @@ check_hidden_cost(struct clfs *fs, BLOCK
 			/*
 			 * Look for IFILE blocks, unless this is the Ifile.
 			 */
-			if (bip[i].bi_inode != clfs_sb_getifile(fs)) {
+			if (bip[i].bi_inode != lfs_sb_getifile(fs)) {
 				lbn = lfs_sb_getcleansz(fs) + bip[i].bi_inode /
 							lfs_sb_getifpb(fs);
-				*ifc += check_or_add(clfs_sb_getifile(fs), lbn,
+				*ifc += check_or_add(lfs_sb_getifile(fs), lbn,
 						     bip, bic, &ebip, &ebic);
 			}
 		}
@@ -1021,7 +1021,7 @@ clean_fs(struct clfs *fs, CLEANERINFO *c
 	for (i = 0; i < lfs_sb_getnseg(fs); i+= lfs_sb_getsepb(fs)) {
 		bread(fs->lfs_ivnode,
 		      lfs_sb_getcleansz(fs) + i / lfs_sb_getsepb(fs),
-		      clfs_sb_getbsize(fs), 0, &bp);
+		      lfs_sb_getbsize(fs), 0, &bp);
 		for (j = 0; j < lfs_sb_getsepb(fs) && i + j < lfs_sb_getnseg(fs); j++) {
 			sup = ((SEGUSE *)bp->b_data) + j;
 			fs->clfs_segtab[i + j].nbytes  = sup->su_nbytes;
@@ -1055,10 +1055,10 @@ clean_fs(struct clfs *fs, CLEANERINFO *c
 	ngood = 0;
 	if (use_bytes) {
 		/* Set attainable goal */
-		goal = clfs_sb_getssize(fs) * atatime;
-		if (goal > (cip->clean - 1) * clfs_sb_getssize(fs) / 2)
-			goal = MAX((cip->clean - 1) * clfs_sb_getssize(fs),
-				   clfs_sb_getssize(fs)) / 2;
+		goal = lfs_sb_getssize(fs) * atatime;
+		if (goal > (cip->clean - 1) * lfs_sb_getssize(fs) / 2)
+			goal = MAX((cip->clean - 1) * lfs_sb_getssize(fs),
+				   lfs_sb_getssize(fs)) / 2;
 
 		dlog("%s: cleaning with goal %" PRId64
 		     " bytes (%d segs clean, %d cleanable)",
@@ -1071,7 +1071,7 @@ clean_fs(struct clfs *fs, CLEANERINFO *c
 			if (fs->clfs_segtabp[i]->priority == 0)
 				break;
 			/* Upper bound on number of segments at once */
-			if (ngood * clfs_sb_getssize(fs) > 4 * goal)
+			if (ngood * lfs_sb_getssize(fs) > 4 * goal)
 				break;
 			sn = (fs->clfs_segtabp[i] - fs->clfs_segtab);
 			dlog("%s: add seg %d prio %" PRIu64
@@ -1122,7 +1122,7 @@ clean_fs(struct clfs *fs, CLEANERINFO *c
 	/* Record statistics */
 	for (i = nb = 0; i < bic; i++)
 		nb += bip[i].bi_size;
-	util = ((double)nb) / (fs->clfs_nactive * clfs_sb_getssize(fs));
+	util = ((double)nb) / (fs->clfs_nactive * lfs_sb_getssize(fs));
 	cleaner_stats.util_tot += util;
 	cleaner_stats.util_sos += util * util;
 	cleaner_stats.bytes_written += nb;
@@ -1134,14 +1134,14 @@ clean_fs(struct clfs *fs, CLEANERINFO *c
 	 * XXX do something about this.
 	 */
 	if_extra = 0;
-	extra = clfs_sb_getbsize(fs) * (off_t)check_hidden_cost(fs, bip, bic, &if_extra);
-	if_extra *= clfs_sb_getbsize(fs);
+	extra = lfs_sb_getbsize(fs) * (off_t)check_hidden_cost(fs, bip, bic, &if_extra);
+	if_extra *= lfs_sb_getbsize(fs);
 
 	/*
 	 * Use markv to move the blocks.
 	 */
 	if (do_small) 
-		inc = MAXPHYS / clfs_sb_getbsize(fs) - 1;
+		inc = MAXPHYS / lfs_sb_getbsize(fs) - 1;
 	else
 		inc = LFS_MARKV_MAXBLKCNT / 2;
 	for (mc = 0, mbip = bip; mc < bic; mc += inc, mbip += inc) {
@@ -1183,9 +1183,9 @@ clean_fs(struct clfs *fs, CLEANERINFO *c
 	       lfs_sb_getfsmnt(fs), (int64_t)nb, (int64_t)(extra - if_extra),
 	       (int64_t)if_extra, (int64_t)(nb + extra), ngood,
 	       (ngood ? (int64_t)(100 - (100 * (nb + extra)) /
-					 (ngood * clfs_sb_getssize(fs))) :
+					 (ngood * lfs_sb_getssize(fs))) :
 		(int64_t)0));
-	if (nb + extra >= ngood * clfs_sb_getssize(fs))
+	if (nb + extra >= ngood * lfs_sb_getssize(fs))
 		syslog(LOG_WARNING, "%s: cleaner not making forward progress",
 		       lfs_sb_getfsmnt(fs));
 
@@ -1221,13 +1221,13 @@ needs_cleaning(struct clfs *fs, CLEANERI
 	 * the cached information, so invalidate the buffer before
 	 * handing it back.
 	 */
-	if (bread(fs->lfs_ivnode, 0, clfs_sb_getbsize(fs), 0, &bp)) {
+	if (bread(fs->lfs_ivnode, 0, lfs_sb_getbsize(fs), 0, &bp)) {
 		syslog(LOG_ERR, "%s: can't read inode", lfs_sb_getfsmnt(fs));
 		return -1;
 	}
 	*cip = *(CLEANERINFO *)bp->b_data; /* Structure copy */
 	brelse(bp, B_INVAL);
-	cleaner_stats.bytes_read += clfs_sb_getbsize(fs);
+	cleaner_stats.bytes_read += lfs_sb_getbsize(fs);
 
 	/*
 	 * If the number of segments changed under us, reinit.

Index: src/sys/ufs/lfs/lfs_accessors.h
diff -u src/sys/ufs/lfs/lfs_accessors.h:1.1 src/sys/ufs/lfs/lfs_accessors.h:1.2
--- src/sys/ufs/lfs/lfs_accessors.h:1.1	Tue Jul 28 05:09:34 2015
+++ src/sys/ufs/lfs/lfs_accessors.h	Tue Jul 28 05:14:23 2015
@@ -1,4 +1,4 @@
-/*	$NetBSD: lfs_accessors.h,v 1.1 2015/07/28 05:09:34 dholland Exp $	*/
+/*	$NetBSD: lfs_accessors.h,v 1.2 2015/07/28 05:14:23 dholland Exp $	*/
 
 /*  from NetBSD: lfs.h,v 1.165 2015/07/24 06:59:32 dholland Exp  */
 /*  from NetBSD: dinode.h,v 1.22 2013/01/22 09:39:18 dholland Exp  */
@@ -483,7 +483,7 @@ LFS_DEF_SB_ACCESSOR(u_int32_t, resvseg);
  * lfs_sboffs is an array
  */
 static __unused inline int32_t
-lfs_sb_getsboff(struct lfs *fs, unsigned n)
+lfs_sb_getsboff(STRUCT_LFS *fs, unsigned n)
 {
 #ifdef KASSERT /* ugh */
 	KASSERT(n < LFS_MAXNUMSB);
@@ -491,7 +491,7 @@ lfs_sb_getsboff(struct lfs *fs, unsigned
 	return fs->lfs_dlfs.dlfs_sboffs[n];
 }
 static __unused inline void
-lfs_sb_setsboff(struct lfs *fs, unsigned n, int32_t val)
+lfs_sb_setsboff(STRUCT_LFS *fs, unsigned n, int32_t val)
 {
 #ifdef KASSERT /* ugh */
 	KASSERT(n < LFS_MAXNUMSB);
@@ -503,7 +503,7 @@ lfs_sb_setsboff(struct lfs *fs, unsigned
  * lfs_fsmnt is a string
  */
 static __unused inline const char *
-lfs_sb_getfsmnt(struct lfs *fs)
+lfs_sb_getfsmnt(STRUCT_LFS *fs)
 {
 	return fs->lfs_dlfs.dlfs_fsmnt;
 }

Reply via email to